首页 技术 正文
技术 2022年11月12日
0 收藏 557 点赞 3,952 浏览 1315 个字

群里有朋友求解一个问题,高分求一条HQL多对多查询语句 。

问题描述见 http://topic.csdn.net/u/20090621/16/4eac6fe0-bf3e-422e-a697-f7584732f66e.html,摘要如下:

Hibernate多对多关联映射的HQL中的in条件查询问题一个学科表(Field),一个用户表(User),多对多关系。 
Hibernate多对多关联映射的HQL中的in条件查询问题学科表有两个字段,id和descripiton,用户表有众多字段,不罗列了 
Hibernate多对多关联映射的HQL中的in条件查询问题Field中有SET集合users 
Hibernate多对多关联映射的HQL中的in条件查询问题User中有SET集合fields 
Hibernate多对多关联映射的HQL中的in条件查询问题现在要查掌握id like ‘520%’的女性用户 
Hibernate多对多关联映射的HQL中的in条件查询问题我这样写的: 
Hibernate多对多关联映射的HQL中的in条件查询问题from User u,Field f where u.gender=’m’ in (select f.users from Field where f.id like ‘520%’) 
Hibernate多对多关联映射的HQL中的in条件查询问题持续报错! 

我的项目代码中恰好有一个多对多的关联映射的类:User(用户)和Role(角色),其中,User类中有roles集合,而Role类中有users集合。我用我的代码测试了一番。

首先写了下面这句:

select user from User user where user.sex=’男’ and user in (select role.users from Role role where role.id>5)

这样不行,报错。原因是,Hibernate的HQL语句中的“in条件”句如:x 
in(‘a’,’b’,’c’),要求的是x是(‘a’,’b’,’c’)中的一个元素,而select
role.users这样查出来的是集合的集合,它内部的元素应该是一个集合:set<user> in (select
role.users…),而不是一个对象: user in (select role.users…)。

可惜的是HQL语句没有set<user> in (select
role.users….)这样的子句,后来,查了一下Hibernate的参考文档,得到解决方法。原来,Hibernate的HQL语句中的“in条
件”中,可加入”elements”关键词,即上面的查询语句变成:

select user from User user,Role role where user.sex=’男’ and user in elements(role.users) and role.id>5

这样就行了。

不过还有一个小问题,就是这样查询出来,会出现许多重复记录,原因是查询出的每一个符合的role后,会通过role.getUsers()查出
users集合,这样,当然就可能出现有几个role拥有相同的user的现象。很容易解决,加多一个“distinct ”关键词就行。

select distinct  user from User user,Role role where user.sex=’男’ and user in elements(role.users) and role.id>5

好了,解决了。那位CSDN中的朋友提的问题也解决了,它的hql语句如下:

select distinct u from User u,Field f where u.gender=’m’ and u in elements(f.users) and f.id like ‘520%’

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,488
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,903
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,737
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,489
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,128
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,290