Hibernate通过SQL查询常量时只能返回第一个字符的解决方法

来源:互联网 发布:自定义域名邮箱 编辑:程序博客网 时间:2024/05/19 13:25


在Hibernate中如果通过

session.createSQLQuery("select '合计' as name from dual").list()  

 

查询,返回值中只会有一个“合”字。

经查,常量在数据库中被认为是CHAR类型的,Hibernate取值时将其保存为Character类型,而Character只能保存一个字符,所以造成返回值中只存在一个字符。Hibernate官方已存在此bug ,却从未修复。

该bug中给出2中解决方法:

1.继承一个Dialect,并注册CHAR类型的对应方式。代码如下

public class MySQLServerDialect extends org.hibernate.dialect.SQLServerDialect  
  1. {  
  2.     public MySQLServerDialect()  
  3.     {  
  4.         super();  
  5.         //very important, mapping char(n) to String  
  6.         registerHibernateType(Types.CHAR, Hibernate.STRING.getName());  
  7.     }  
  8. }  

 

2.设置字段对应的类型(缺点是如果查询很多字段,每个字段都必须设置,没设置类型的字段在结果集中是不存在的),代码如下

session.createSQLQuery("select '合计' as name from dual").addScalar("name", Hibernate.STRING).list()  

 

还有一种解决方法是在SQL中设置该字段的类型,代码如下

session.createSQLQuery("select cast('合计' as varchar(4)) as name from dual").list()  

 

该方法在Oracle和SQL Server中可用。

Hibernate中将SQL查询出来字段转换为对象的方法有两种

1.使用ResultTransformer,代码如下

  1. query.setResultTransformer(new AliasToBeanResultTransformer(StudentDTO.class)).list()  

 

这种方法要求数据库的字段名和类的属性的大小写必须一致,但是Oracle查询返回的字段名却全是大写。

2.使用addEntity方法,这种方法的缺点是SQL必须写成select * from users的形式或select {a.*},{b.*} from a,b where...的格式。


转载至:http://www.blogjava.net/hwpok/archive/2011/05/05/349585.html,谢谢




0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 两周的宝宝便秘怎么办 3岁宝宝不肯吃药怎么办 1岁婴儿不肯吃药怎么办 9月婴儿不肯吃药怎么办 半岁宝宝不吃药怎么办 1岁宝宝不爱吃药怎么办 2岁吃多了呕吐怎么办啊 小孩吃撑了吐怎么办 三岁宝宝吃太多怎么办 小孩吃撑发烧了怎么办 婆婆不帮忙带孩子怎么办 孩子在中班幼儿园不爱写字怎么办 小孩不愿意上学不愿意写字怎么办 宝妈太内向不喜欢带孩子出门怎么办 宝宝吃饭不带围兜怎么办 宝宝吃饭不喜欢带围兜怎么办 宝宝吃饭不爱带围兜怎么办 孩子不吃肉和菜怎么办 我很恶心我婆婆怎么办 坐月子不喜欢婆婆抱宝宝怎么办 宝宝一写字就哭怎么办 4岁宝宝不爱学习怎么办 4岁宝宝不爱写字怎么办 孩子调皮老师不让上学了怎么办 小学生写字握笔握出剪子来怎么办 儿子6岁不会写字怎么办 宝宝在幼儿园不说话怎么办 孩子上幼儿园不说话怎么办 幼儿写数字不写怎么办 小孩不吃饭怎么办 十个月 十个月小孩不爱吃饭怎么办 十个月的小孩不吃饭怎么办 家长要调幼儿园监控怎么办 自己带孩子婆婆生气怎么办 婆婆老是觉得我奶水不够怎么办 1岁小儿特别懒怎么办 17的孩子很懒怎么办 上大班的孩子不愿写字怎么办 快上中班的小朋友不爱学习怎么办 小学生两边肩膀不平应该怎么办 写字右肩膀疼是怎么办