hibernate中对于数据库的Text注解出现 No Dialect mapping for JDBC type: -1解决方法

本文介绍了解决Hibernate在处理MySQL数据库Text类型字段时遇到的问题。通过自定义方言类并注册Text类型,使得能够正常进行SQL查询操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

hibernate中对于数据库的Text数据类型不支持。
   hibernate 使用hql查询包含text类型字段的时候很好。如果使用native sql也就是使用  createSQLQuery方法查询text类型的时候总是报错:
org.hibernate.MappingException: No Dialect mapping for JDBC type:-1
       atorg.hibernate.dialect.TypeNames.get(TypeNames.java :56)

是hibernate与mysql的jdbc驱动配合上出现了问题:对于 mysql text类型jdbc  ResultSetMetaData.getColumnType  返回-1  ,而hibernate没有注册该类型,所以导致createSQLQuery 报 No Dialect mapping for JDBCtype: -1。


解决方法:

1、写个类集成方言,然后自己实现对text的支持

import java.sql.Types;  
 import org.hibernate.dialect.MySQL5Dialect;  
 public class DialectForInkfish extends MySQL5Dialect {  
     public DialectForInkfish() {  
         super();  
         registerHibernateType(Types.LONGVARCHAR, 65535, "text");  
     }  
 }  

2、

修改Hibernate配置文件hibernate.cfg.xml,把 

<property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>  
修改为: 
<property name="dialect">com.ibm.crl.inkfish.config.DialectForInkfish</property> 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值