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>
评论
jackytang520 2008-09-05
呵呵,对于Hibernate我也算不上很熟练,大家互相学习吧,最近都很久没弄了
yyy851124 2008-09-05
太高兴看到了。 出这样的问题. 我们这些菜鸟 是没办法解决的.
能交个朋友吗?
发表评论

您还没有登录,请登录后发表评论

jackytang520
搜索本博客
我的相册
2ee9f3fa-178a-3292-859f-60db9b995272-thumb
image031
共 53 张
存档
最新评论