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>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM