No Dialect mapping for JDBC type: 3 解决方法:
出现这个原因是说服务器端的数据类型并不能和Java的BigDecimal数据类型成功映射。
推想只要在Hibernate里把本对应的数据类型成功映射起来就可以成功执行了。
解决案如下:
1、新建一个MySQLServerDialect extends org.hibernate.dialect.SQLServerDialect 并在里面补充注册新的类型映射。如下:
public class MySQLServerDialect extends SQLServerDialect{
public MySQLServerDialect() {
super();
registerHibernateType(Types.DECIMAL, Hibernate.BIG_DECIMAL.getName());
}
}
2、把Hibernate里的Dialect改成我们第一步新建的新的Dialect
<prop key="hibernate.dialect">com.gdnfha.atcs.common.MySQLServerDialect</prop>
经过这两步这后就可以正常使用SqlQuery拿到Sql Server 2005里的decimal类型了。
在SQLServerDialect里的registerHibernateType函数,更详细的用法请看: