自定义Hibernate Dialect解决createSQLQuery时的decimal,long
org.hibernate.MappingException: No Dialect mapping for JDBC type: 3仔细查看,发现问题在于数据类型.到网上查,发现hibernate在执行List result = session.createSQLQuery(sql).list()的时候,当SQL语句中遇到的decimal,long等类型的字段时,就出现上面的错误.而且从错误信息中可以发现:出错的是Dialect.
解决办法:
错误知道以后,我就到网上找解决办法.看来遇到这类问题的人太多了,网上到处都有人贴这个问题.我看了几篇,发现有个解决办法,就是自定义Hibernate Dialect.虽然所用数据库不同(我用的数据库是DB2),我觉得大同小异,就照着做了:
首先建一个类,继承org.hibernate.dialect.DB2Dialect,该类的内容如下:
import java.sql.Types;import org.hibernate.Hibernate;import org.hibernate.dialect.DB2Dialect;public class PmDb2Dialect extends DB2Dialect { public PmDb2Dialect() { super(); registerHibernateTyp(Types.DECIMAL,Hibernate.BIG_DECIMAL.getName()); }}
第二步,就是修改hibernate的配置文件hibernate.cfg.xml:
将:
<property name="hibernate.dialect"> org.hibernate.dialect.DB2Dialect </property>
改为:
<property name="hibernate.dialect"> com.yonder.pm.common.PmDb2Dialect </property>
页:
[1]