工作中遇到原生的hibernate方言无法将数据库中的某些数据类型映射到java类中,需要做两个操作:
1、创建类继承自原方言类,并修改所要更改的数据类型,代码如下:
package com.lkscn.base.dialect;
import java.sql.Types;
import org.hibernate.Hibernate;
import org.hibernate.dialect.MySQL5Dialect;
public class MyDialectForInkfish extends MySQL5Dialect {
public MyDialectForInkfish(){
super();
//数据库中的longchar类型映射为text类型
registerHibernateType(Types.LONGVARCHAR, 65535, "text");
registerHibernateType(Types.LONGVARCHAR, 65535, "longtext");
registerHibernateType(Types.DECIMAL, Hibernate.BIG_DECIMAL.getName());
registerHibernateType(-1, Hibernate.STRING.getName());
}
}
2、修改配置文件
<!-- MySql 数据源配置 --> <property name="hibernateProperties"> <value> hibernate.cache.use_query_cache=true hibernate.cache.use_second_level_cache=true hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider <!-- hibernate.dialect=org.hibernate.dialect.MySQLDialect --> hibernate.dialect=com.lkscn.base.dialect.MyDialectForInkfish hibernate.hbm2ddl.auto=update <!--hibernate.show_sql=show --> hibernate.format_sql=true hibernate.jdbc.fetch_size=5 hibernate.jdbc.batch_size=30 </value> </property>
转载于:https://blog.51cto.com/brightaries/1955296