繁体   English   中英

嵌套选择的休眠条件

[英]Hibernate Criteria for nested select

我有要选择其条件的sql选择。 我在谷歌上搜索了一段时间,但找不到“ not in”的任何内容。 我的SQL查询:

select * from users where username not in(
select users.username from users right join authorities on users.username=authorities.username 
where authority='ROLE_ADMIN')  

非常感谢。 问候,垫子

感谢您的回答,但并非完全如此。 您选择了所有具有权限“ ROLE_ADMIN”的用户,而我需要的不是“ ROLE_ADMIN”的所有用户。 smple“ not”不起作用,因为有些用户一次拥有“ ROLE_ADMIN”和“ ROLE_MODERATOR”。 我设法解决这个问题:

DetachedCriteria subCriteria = DetachedCriteria.forClass(Authorities.class);
subCriteria.add(Property.forName("authority").ne(authorityName));
subCriteria.setProjection(Projections.property("users"));

DetachedCriteria criteria = DetachedCriteria.forClass(getPersistentClass());
criteria.add(Property.forName("username").notIn(subCriteria));
return getHibernateTemplate().findByCriteria(criteria);

它有效,但是您认为这是一个很好的解决方案吗?

您应该在Hibernate映射中将权限映射为类user的属性。

<many-to-one name="authority" class="Authority" column="AUTHORITY_ID"

之后,很容易构建条件查询:

List users = sess.createCriteria(User.class)
.createCriteria("authority")
.add( Restrictions.eq("authority_name", "ROLE_ADMIN") )
.list

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM