让JPA的Query查询接口返回Map对象的方法
在JPA2.0中我们可以使用entityManager.createNativeQuery()来执行原生的SQL语句。但当我们查询结果没有对应实体类时,query.getResultList()返回的是一个List
常见的用法是这样的:
publicvoidtestNativeQuery(){ Queryquery=entityManager.createNativeQuery("selectid,name,agefromt_user"); Listrows=query.getResultList(); for(Objectrow:rows){ Object[]cells=(Object[])row; System.out.println("id="+cells[0]); System.out.println("name="+cells[1]); System.out.println("age="+cells[2]); } }
这样用会使代码非常不容易让人理解,究竟下标为0的元素到底是什么,不去数查询语句是不知道的,而且一旦查询语句被调整,Java代码也要一起调整。这时候我们想如果返回的是Map的话,用起来会清晰的多。
可惜的是JPA的API中并没有提供这样的设置。其实很多JPA的底层实现都是支持返回Map对象的。
例如:
EclipseLink的query.setHint(QueryHints.RESULT_TYPE,ResultType.Map); Hibernate的.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
所以,如果我们想要返回Map并且确定底层用的是某一种JPA的实现时我们可以退而求其次,牺牲跨实现的特性来满足我们的需求:
publicvoidtestNativeQuery(){ Queryquery=entityManager.createNativeQuery("selectid,name,agefromt_user"); query.unwrap(SQLQuery.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP); Listrows=query.getResultList(); for(Objectobj:rows){ Maprow=(Map)obj; System.out.println("id="+row.get("ID")); System.out.println("name="+row.get("NAME")); System.out.println("age="+row.get("AGE")); } }
Query返回指定entity返回类型的写法
Queryquery=entityManager.createNativeQuery("selectid,name,agefromt_user",User.Class);
这里需要注意的是,用Map肯定要比用Object数组来的效率低。所以你要看性能下降是否在可接受范围内。再就是在我的Hibernate4.2.x的环境下,无论你原生SQL中写的是大写字母还是小写字母,返回的字段名都是大写的。当然你可以通过自定义ResultTransformer的形式对字段名进行一定的处理,甚至是返回自己需要的POJO。
以上这篇让JPA的Query查询接口返回Map对象的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。