SQLAlchemy 在同一个表中,求交集,该怎么查询呢?

2016-12-05 18:57:51 +08:00
 rogwan

数据表结构(student_id / class_id / room_id 三个字段全是多对多关系,三个字段组成联合 primary key)如下:

student_id - class_id - room_id
student1 --- english --- 1
student1 --- english --- 2
student1 --- math --- 3
student2 --- math --- 3
student2 --- Chinese --- 2
student3 --- math --- 3
student4 --- english --- 1
student4 --- english --- 3
student5 --- english --- 1
student5 --- english --- 2
student5 --- english --- 6
student5 --- math --- 3

1 、求同时在上 english 和 math 课的学员名单;

2 、拓展一下:学员人数再增加,课程科目再增加,教室数量再增加。求给定同时在上某几个科目的学员名单,要怎么查询呢?比如:求同时在上 english 、 math 、 history 三个科目的学员名单?求同时在上 N 个科目的学员名单?

SQL 可以用 InterSect 来查询不同表的交集,但是同一个表的交集、且如果是查询 N 个科目,就是说别名的表的数量也是不确定的,要怎么查呢?

用 SQLAlchemy 来处理,也会遇到同样的问题,用 inner join 来查询,遇到 N 个科目(就是要别名 N 次?)该怎么查询呢?

1708 次点击
所在节点    Python
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/325466

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX