jackytang520 发表于 2013-1-13 19:02:46

自定义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]
查看完整版本: 自定义Hibernate Dialect解决createSQLQuery时的decimal,long