文档章节

在hibernate中查询使用List,Map和类对象定制返回类型

王春-海子
 王春-海子
发布于 2016/04/13 11:56
字数 714
阅读 15
收藏 0

在使用hibernate进行查询时,使用得最多的还是通过构建hql进行查询了。在查询的过程当中,除使用经常的查询对象方法之外,还会遇到查询一个属性,或一组聚集结果的情况。在这种情况下,我们通常就需要对返回的结构进行处理。
一般情况下,我们通过构建hql,并通过设置query的resultTransformer来定制返回结果的类型,一般设置为map属性,如下所示:

Query query = session.createQuery("hql");?

query.setResultTransformer(CriteriaSpecification.ALIAS_TO_ENTITY_MAP);

来指定查询结果的每一项为一个map。
不过,随着hibernate的发展,可以在hql中直接使用集合查询语句,如list和map了。以下分别介绍使用List和Map时的查询语句以及查询结果。首先,数据库的数据如下所示:

mysql> select * from p_dictionary;

+-----------------+----+---------+------+--------+--------+

| dictionary_type | id | version | code | forbid | value |

+-----------------+----+---------+------+--------+--------+

| COUNTY | 1 | 0 | 001 | | 四川 |

| COUNTY | 2 | 0 | 002 | | 北京 |

| COUNTY | 3 | 0 | 001 | NULL | 四川 |

+-----------------+----+---------+------+--------+--------+

3 rows in set (0.00 sec)

以下分别介绍使用list和map的查询语句和查询结果:

使用List

String query = "select new List(p.code, p.value) from Dictionary p";

List list = session.createQuery(query).list();

System.out.println(list);

//结果: [[001, 四川],[002,北京],[001,四川]]

?

使用Map,首先不指定alias,则结果的键就按照查询出来的顺序结果,使用0,1来表示key

String query = "select new Map(p.code, p.value) from Dictionary p";

List list = session.createQuery(query).list();

//结果:[{1=四川, 0=001},{1=北京, 0=002},{1=四川, 0=001}]

?

使用Map,指定alias,则结果中的key则为alias

String query = "select new Map(p.code as code, p.value as value) from Dictionary p";

List list = session.createQuery(query).list();

//结果:[{value=四川, code=001},{value=北京, code=002},{value=四川, code=001}]

?

如果部分使用alias,部分不使用,则使用了alias的将使用alias作为key,没有使用的则仍然使用序号代替,其中序号则为在查询结果的序号

String query = "select new Map(p.code as code, p.value) from Dictionary p";

List list = session.createQuery(query).list();

//结果:[{1=四川, code=001},{1=北京, code=002},{1=四川, code=001}]

--------------------------------------------------------------------------------------------------

select new List(p.name, p.address) from Person as p ;
select将选择出来的属性存入一个List对象中

select new ClassTest(p.name, p.address) from Person as p;
select将选择出来的属性封装成对象,前提是ClassTest支持p.name, p.address的构造函数,

select new Map(p.name as personName) from Person as p ;
select将选中的表达式命名为别名,这种用法与new Map()结合,选择出来的是Map结构,
以personName为key,将实际选择出来的值作为value


本文转载自:http://blog.knowsky.com/255131.htm

共有 人打赏支持
王春-海子
粉丝 7
博文 49
码字总数 11981
作品 0
江北
技术主管
在hibernate中查询使用list,map定制返回类型

在使用hibernate进行查询时,使用得最多的还是通过构建hql进行查询了。在查询的过程当中,除使用经常的查询对象方法之外,还会遇到查询一个属性,或一组聚集结果的情况。在这种情况下,我们通...

SHUIMOMO
2017/10/11
0
0
hibernate sql 查询

Hibernate 支持使用原生的SQL查询,使用原生SQL查询可以利用某些数据库特性,原生SQL查询也支持将SQL语句放在配置文件中配置,从而提高程序的解耦,命名SQL查询还可以用于调用存储过程。 SQL查...

DaDa-da
04/23
0
0
hibernate一些函数理解

uniqueResult(); 这个方法是这样用的 当你能够肯定你的数据库中根据你的查询条件只会返回唯一结果,就可以用这个方法! 否则就用list(); 其返回类型为 List<T> 可根据你的实际类型强转!...

小湘西
2016/09/20
4
0
hibernate下查询数据返回List,类型匹配错误。

好久没写博客了。直接上出问题的代码: List resultList = new ArrayList();try{if(!map.isEmpty()){String pageNo = map.get("pageNo");String rowsInOnePage = map.get("rowsInOnePage");S......

渔樵耕读
2014/09/04
0
0
Hibernate Query数据查询

主要由三种查询:HQL查询、Criteria条件查询、SQL查询。 以下分别讲解 1. HQL查询 HQL(Hibernate Query Language)查询提供了更加丰富和灵活的查询特性,因此Hibernate将HQL查询立为官方推荐的...

疯子船长
2015/10/26
1K
0

没有更多内容

加载失败,请刷新页面

加载更多

Qt那些事0.0.7

在帮助文档(Overview - QML and C++ Integration)中随缘遇到一张图,是关于C++对象与QML整合介绍的,值得标记下来,虽然大部分功能也有所涉猎,但是还是留个记号,万一哪天我失忆了还想写Q...

Ev4n
19分钟前
0
0
快速幂运算

题:求一个数 data 的 n 次幂,要求时间复杂度为log(n) 1:递归算法: /** * x^3=(x^2)*x;x^7=(x^3)^2 * x * * 递归算法 * @param data 底数 * @param n 次...

偶尔诗文
23分钟前
1
0
Google 宣布将会关闭消费者版本 Google+

Google 家的社交平台 Google+ 原来曾经在今年 3 月发生了一次严重的用户资料外泄事故,但这科网巨擘却一直保密,直至今天华尔街日报把事件披露之后才确认事件。Google 在重申问题已经即时解决...

问题终结者
37分钟前
1
0
腾讯三大运维开源项目齐聚“OSCAR开源先锋日”

10月20日,腾讯开源三大运维开源项目——TARS、蓝鲸和织云Metis首次集结,参与了由中国信息通信研究院主办、云计算标准与开源推进委员会承办的 “OSCAR开源先锋日”。会上,腾讯开源团队与前...

腾讯开源
42分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部