weixin_42357729 2010-03-01 11:06
浏览 221
已采纳

请问hibernate中如何实现不存(not extsts)在查询?

有如下的数据结构
角色表
create table role(
roleid integer,
rolename varchar2(32)
)

用户表
create table userinfo(
userid integer,
username varchar2(32)
)

用户和角色关联表
create table user_role(
userid integer,
roleid integer,
)

java的实体对象也比较简单就不贴出来了,其中Userinfo.java中定义了关联
private List roleList = new ArrayList();

@ManyToMany
@JoinTable(name = "user_role", joinColumns = { @JoinColumn(name = "userid") }, inverseJoinColumns = { @JoinColumn(name = "roleid") })
@Fetch(FetchMode.SUBSELECT)
@OrderBy("roleid")
public List<Role> getRoleList() {
    return roleList;
}


public void setRoleList(List<Role> roleList) {
    this.roleList = roleList;
}

现在我像实现的查询效果是这样的,
有已经一个用户对象,userid=5150,我想查询出角色列表,但是要过滤掉用户5150已经拥有的角色,就是要得到还有和用户5150建立关联的所有角色列表。 下面是标准的sql的查询方式
select * from role where not exists (select * from user_role where role.roleid=user_role.roleid and user_role.userid=5150)

我想请问在hibernate如何通过QBC或者Hsq语句来进行查询。
谢谢

  • 写回答

3条回答 默认 最新

  • zhangrunzgz 2010-03-03 09:34
    关注

    from role left join user_role on userid <> 5150 。类似这样就可以实现了。我没具体测试,你试试吧。 :D

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 写uniapp时遇到的问题
  • ¥15 vs 2008 安装遇到问题
  • ¥15 matlab有限元法求解梁带有若干弹簧质量系统的固有频率
  • ¥15 找一个网络防御专家,外包的
  • ¥100 能不能让两张不同的图片md5值一样,(有尝)
  • ¥15 informer代码训练自己的数据集,改参数怎么改
  • ¥15 请看一下,学校实验要求,我需要具体代码
  • ¥50 pc微信3.6.0.18不能登陆 有偿解决问题
  • ¥20 MATLAB绘制两隐函数曲面的交线
  • ¥15 求TYPCE母转母转接头24PIN线路板图