hibernate 双向多对多查询问题

炎龙的李 2007-12-07 06:38:10
还是那个老问题
有表student(id,name) course(id,name) student_course(student_id,course_id)

使用many-to-many关联
student
course

如何查询没有选修的生物课的学生?
select distinct a from student a inner join a.courses as b where b.name!='生物课'
这样可以查询出所有没有选修生物课但是选修了其他课程的学生,即在student_course中有记录的学生。但是没有选择任何课程的学生不在查询结果中,请问如何解决??
...全文
127 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
baobeituping 2007-12-10
  • 打赏
  • 举报
回复
因为要出现没有选课程的学生,也就是该学生的学号肯定不能出现在中间表中,满足这个条件就可以了
select distinct(s.name) from student s right outer join student_course sc
on s.name not in
(select s.name from student s,student_course sc
where s.id=sc.studentid)
;
Jahson 2007-12-10
  • 打赏
  • 举报
回复
left join fetch 连接方式吧
schumiXsuse 2007-12-10
  • 打赏
  • 举报
回复
有没有建中间关联表?

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧