12.10 简化 SQL 双重否定的一个示例

 

根据一个表中数据,查询与另一个表中能够匹配的记录,在 SQL 处理中通过双重否定可以减少运算量。
根据选课表、课程表和学生表,查询选修了所有课程的学生。

Student
ID
Name
Class
SelectCourse
ID
CourseID
StudentID
Course
ID
Name
TeacherID

脚本:

A
1 =connect(“db”)
2 =A1.query(“select * from Student”)
3 =A1.query(“select * from Course”)
4 =A1.query@x(“select * from SelectCourse”)
5 =A4.groups(StudentID; icount(CourseID):CourseCount)
6 =A5.select(CourseCount==A3.len())
7 =A2.join@i(ID, A6:StudentID)

A1 连接数据库
A2 查询学生表
A3 查询课程表
A4 查询选课表
A5 选课表按照学生 ID 分组汇总每个学生的选课数量
A6 选出选择了所有课程的学生 ID
A7 使用 A.join@i() 函数连接过滤

运行结果:

ID Name Class
4 Emily Smith Class 1