sqlserver org.hibernate.MappingException: No Dialect mapping for JDBC type: -9

No Dialect mapping for JDBC type: -9

由于项目中使用的是hibernate 4.35版本和sqlserver 2008数据库。所以,自定义方言时,需要和老版本做区别:

复制代码
public class MySQLServerDialect extends SQLServerDialect {
 public MySQLServerDialect()
 {
     super();
     registerHibernateType(1, "string");     
     registerHibernateType(-9, "string");     
     registerHibernateType(-16, "string");     
     registerHibernateType(3, "double");  
       
     registerHibernateType(Types.CHAR, StandardBasicTypes.STRING.getName());     
     registerHibernateType(Types.NVARCHAR, StandardBasicTypes.STRING.getName());     
     registerHibernateType(Types.LONGNVARCHAR, StandardBasicTypes.STRING.getName());     
     registerHibernateType(Types.DECIMAL, StandardBasicTypes.DOUBLE.getName());
 }
}
复制代码

然后注意修改hibernate 配置。本项目是将hibernate托管于spring,

复制代码
  <property name="hibernateProperties">
  <props>
   <prop key="hibernate.show_sql">true</prop>
   <prop key="current_session_context_class">thread</prop>
  <!--   <prop key="hibernate.dialect">org.hibernate.dialect.SQLServerDialect</prop> -->
  <prop key="hibernate.dialect">manage.myextends.sqlserver.MySQLServerDialect</prop> 

  </props>
  </property>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值