No Dialect mapping for JDBC type 错误分析,Hibernate和数据库类型对应

本文详细解析了在使用Hibernate时遇到的关于NoDialectmappingforJDBCtype错误的原因,并提供了针对性的解决方法,包括配置方言、调整数据库字段类型等。
当在hibernate中运用原始的sql语句进行操作的的时候,常常会报错,错误很多都是关于 
No Dialect mapping for JDBC type 类型的错误,经过分析和查找,问题常常发生在几个地方 
1、错误的配置了hibernate的方言 

2、就是你的数据库中的字段和java里面的类型不匹配的问题


查找原因:通过查询hibernate的源码,找到问题的根本所在,就是hibernate中不支持对应的数据类型,具体数据类型的值,请查看下表 

查看 java.sql.Types 类,可以找到对应类型,调整相应的数据库里的类型,或者其他支持这个类型的方言。 

 

java,hibernate和数据库对应的数据类型


Java数据类型Hibernate数据类型标准SQL数据类型
(PS:对于不同的DB可能有所差异)
byte、java.lang.BytebyteTINYINT
short、java.lang.ShortshortSMALLINT
int、java.lang.IntegerintegerINGEGER
long、java.lang.LonglongBIGINT
float、java.lang.FloatfloatFLOAT
double、java.lang.DoubledoubleDOUBLE
java.math.BigDecimalbig_decimalNUMERIC
char、java.lang.CharactercharacterCHAR(1)
boolean、java.lang.BooleanbooleanBIT
java.lang.StringstringVARCHAR
boolean、java.lang.Booleanyes_noCHAR(1)('Y'或'N')
boolean、java.lang.Booleantrue_falseCHAR(1)('Y'或'N')
java.util.Date、java.sql.DatedateDATE
java.util.Date、java.sql.TimetimeTIME
java.util.Date、java.sql.TimestamptimestampTIMESTAMP
java.util.CalendarcalendarTIMESTAMP
java.util.Calendarcalendar_dateDATE
byte[]binaryVARBINARY、BLOB
java.lang.StringtextCLOB
java.io.SerializableserializableVARBINARY、BLOB
java.sql.ClobclobCLOB
java.sql.BlobblobBLOB
java.lang.ClassclassVARCHAR
java.util.LocalelocaleVARCHAR
java.util.TimeZonetimezoneVARCHAR
java.util.CurrencycurrencyVARCHAR

解决办法:

(1)写个类继承SQLServerDialect,注册类型映射

package com.xuedou.skyedu.util;
import java.sql.Types;
import org.hibernate.Hibernate;
import org.hibernate.dialect.SQLServerDialect;
/**
 * 注册nvarchar类型映射
 */
public class SkySQLServerDialect extends SQLServerDialect{
	public SkySQLServerDialect() {
		super(); //调用父类的构造方法(super()一定要放在方法的首个语句)
		registerHibernateType(Types.NVARCHAR, Hibernate.STRING.getName());
	}
}

(2)配置hibernate文件,修改为

hibernate.dialect=com.xuedou.skyedu.util.SkySQLServerDialect


参考文档:http://blog.youkuaiyun.com/xd195666916/article/details/5419316

在使用 TDSQL 时遇到 `No Dialect mapping for JDBC type: 3` 错误,通常表明 Hibernate 无法将 JDBC 类型 3 映射到相应的 Java 类型JDBC 类型 3 对应的是 `DECIMAL` 或 `NUMERIC` 数据库类型Hibernate 在处理查询结果时需要通过方言(Dialect)来识别这些类型并进行映射。 ### 错误原因 1. **方言配置不完整**:当前使用的 Hibernate 方言未注册对 JDBC 类型 3 的支持。 2. **数据库字段类型特殊**:某些数据库(如 TDSQL)可能使用了特殊的 `DECIMAL` 类型表示方式,而默认的 Hibernate 方言未涵盖这种情况。 3. **自定义类型未正确注册**:如果使用了自定义方言或扩展类型,但未在初始化时注册 JDBC 类型 3 的映射规则,则会引发此错误。 ### 解决方案 #### 自定义方言并注册 JDBC 类型 3 可以扩展现有的 Hibernate 方言类,并在构造函数中注册对 JDBC 类型 3 的映射。例如,如果使用的是 SQL Server 方言,可以如下定义自定义方言类: ```java package com.example.hibernate.dialect; import org.hibernate.dialect.SQLServerDialect; import org.hibernate.type.StandardBasicTypes; import java.sql.Types; public class CustomSQLServerDialect extends SQLServerDialect { public CustomSQLServerDialect() { super(); registerHibernateType(Types.DECIMAL, StandardBasicTypes.BIG_DECIMAL.getName()); registerHibernateType(Types.NUMERIC, StandardBasicTypes.BIG_DECIMAL.getName()); } } ``` 然后在 `persistence.xml` 或 Spring Boot 的配置文件中指定该自定义方言: ```properties spring.jpa.properties.hibernate.dialect=com.example.hibernate.dialect.CustomSQLServerDialect ``` #### 使用 `addScalar()` 方法手动映射字段类型 如果使用原生 SQL 查询,可以通过 `addScalar()` 方法显式指定字段的 Hibernate 类型,避免自动映射失败的问题: ```java String sql = "SELECT decimal_column FROM your_table"; List<BigDecimal> results = session.createSQLQuery(sql) .addScalar("decimal_column", StandardBasicTypes.BIG_DECIMAL) .list(); ``` #### 检查依赖版本兼容性 确保 Hibernate 版本与使用的数据库驱动自定义类型库兼容。某些第三方库(如 `hibernate-types`)可能需要特定的 Hibernate 版本支持。如果使用了自动 DDL(如 `spring.jpa.hibernate.ddl-auto`),需注意其与自定义类型加载顺序的冲突。 #### 禁用自动 DDL 如果使用了 `hibernate-types` 等第三方库但仍报错,可以尝试禁用自动 DDL 功能: ```properties spring.jpa.hibernate.ddl-auto=none ``` 这将避免 Hibernate 在启动时进行 schema 管理操作,从而防止类型注册失败的问题。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值