使用HIBERNATE的SQL查询并将结果集自动转换成POJO
在某些场合下,我们可能想使用HIBERNATE的框架提供的SQL查询接口,这时,由于表和实体都可能没有做映射,HIBERNATE不能把结果集转换成你想要的List<POJO>,本文讨论如何在这种情况下让HIBERNATE直接返回你想的结果。下面是简单的查询封装方法
我这个转换器工作的前提是数据库的字段名除了可以含有下杠外,不能再含有其它 POJO对应属性中没有的字符,如USER_ID 对应POJO的userId。
扩展点:
1、可以自定义数据库与POJO属性的对应关系,在查询方法中构造转换器时,通过参数把转换关系传入进来,这样就可实现自由转换了,但请注意这种转换关系只有非常通用才有价值(上面的转换规则就是:字段名 去除下杠 = JAVA属性名),反之如果每个实体都有自已的转换关系,那就还不如编写一个HIBERNATE的映射文件了。
2、本类没有考虑关联,即自定义的对象属性,但这些都不难实现,有兴趣的朋友可结合我的第一篇文章来实现
注意:HIBERNATE3.25以前(后面的没看),对SQL查询的CHAR类型字段处理不好,只返回一位,且是JAVA的CHAR类型,要修改CharacterType类的代码以返回该类型字段的全值
这里我要提示一点,有些时候,有些内容还是不能转换,因为数据类型不一样。这时候就要自己去修改了,将
Object[] tuple,tuple[i]中的变量类型修改,比如tuple[0]中有个变量a 是Long型,但是tuple[i]中的是Bigcimal,
这时候,就要自己写个类比如 chgObject(Object tuple){ a =((BigCimal) tuple[i].getA()).longValue();}