在hibernate项目中提供jdbc接口时,查询数据库char字段的数据只能得到第一个字符的问题,解决方案代码如下:package com.newer.common;import java.sql.Types;
import org.hibernate.Hibernate;
import org.hibernate.dialect.MySQLDialect;
/**
* 此类用于解决数据库 char字段问题(mysql) <br/>
* 因使用hibernate内置提供的sql语句查询接口会给字符串当char处理,
* 所以编写此类覆盖内置的MMySQLDialect <br/>
* 给MYSQL的char字段修饰为String
* @author RSun
* 2012-2-26下午03:53:55
*/
public class MMySQLDialect extends MySQLDialect{
public MMySQLDialect() {
super();
registerHibernateType(Types.DECIMAL, Hibernate.BIG_INTEGER.getName());
registerHibernateType(Types.CHAR, Hibernate.STRING.getName());
registerHibernateType(Types.NVARCHAR, Hibernate.STRING.getName());
registerHibernateType(Types.LONGNVARCHAR, Hibernate.STRING.getName());
}
}
总结:
1. 当前是解决mysql的问题,对应其它数据库只需实现相应的接口即可。
2. 配置<prop key="hibernate.dialect">${dialect}</prop>需引用上面的类。Oracle 缺失INITORCL及Oracle启动过程Oracle VirtualBox + Linux6 + Database 11g 系统安装篇相关资讯 hibernate Hibernate jdbc Hibernate jdbc查询
- Hibernate利用@DynamicInsert和@ (今 07:09)
- Hibernate某些版本(4.3)下报错 (04月20日)
- Hibernate 5.1.0 正式版发布下载 (02月12日)
| - Hibernate的get和load的区别 (08月07日)
- Hibernate3.1.2_中文文档PDF (02月17日)
- Hibernate ORM 5.0.6 发布下载 (12/17/2015 17:12:55)
|
本文评论 查看全部评论 (0)