今天做了个用hibernate直接执行原生sql的查询,报错No Dialect mapping for JDBC type :-9
在网上查了一下。有很多解决方法,这里总结一下。方便大家查找。
第一种: No Dialect mapping for JDBC type: 3;
查看文章
|
ERROR 解决记录 - No Dialect mapping for JDBC type: 3;
2007-11-28 16:34
今天在使用getSession().createSQLQuery("SELECT SUM(aloneIp) FROM table").list();
时出现了错误:No Dialect mapping for JDBC type: 3; baidu,google了一番后,各位都说:“出现这个原因是说服务器端的数据类型并不能和Java的BigDecimal数据类型成功映射。”; 不过我的数据库中“aloneIp”列的类型为INTEGER,出现这个错误不知是何原因。 根据以下解决方法,问题得以解决,记录之: 1、新建一个MMySQLDialect extends org.hibernate.dialect.MySQLDialect (我使用的数据库是MYSQL)并在里面补充注册新的类型映射。如下:
import java.sql.Types;
import org.hibernate.Hibernate; import org.hibernate.dialect.MySQLDialect; public class MMySQLDialect extends MySQLDialect { public MMySQLDialect () { super(); registerHibernateType(Types.DECIMAL, Hibernate.BIG_INTEGER.getName()); } } 2、把Hibernate里的Dialect改成我们第一步新建的新的Dialect
<
prop
key
="hibernate.dialect"
>
[包路径].MMySQLDialect
</
prop
>
|
第二种: org.hibernate.MappingException: No Diale