- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个很难描述的简单问题(至少对我而言)。
考虑数据库建模类(class)的以下模式:
类(class) (cid, did, name, num, creditHours),
学生(sid、fname、lname、did)
ENROLLED_IN(eid、sid、cid)
什么查询可以找到注册 course.name=Math"和 "Science"的学生的 sid?
很抱歉,我问了一个类似的(更简单的)问题,我认为我可以解决剩下的问题,但我做不到:https://stackoverflow.com/questions/18902489/how-to-find-entries-in-database-that-meet-multiple-matches
最佳答案
正如另一页所建议的,您需要对同一个表执行两个 JOIN。但是由于您想使用名称而不是 cid,因此您可以根据注册数据加入类(class)。
SELECT DISTINCT s.sid
FROM STUDENT s
INNER JOIN ENROLLED_IN e ON e.sid = s.sid
INNER JOIN COURSE c ON c.cid = e.cid AND c.Name = 'Math'
INNER JOIN COURSE c2 ON c2.cid = e.cid AND c2.Name = 'Science'
如果你需要整个学生记录,那么......
SELECT STUDENT.*
FROM STUDENT
INNER JOIN
(SELECT DISTINCT s.sid
FROM STUDENT s
INNER JOIN ENROLLED_IN e ON e.sid = s.sid
INNER JOIN COURSE c ON c.cid = e.cid AND c.Name = 'Math'
INNER JOIN COURSE c2 ON c2.cid = e.cid AND c2.Name = 'Science'
) t0 ON t0.sid = STUDENT.sid
EDIT 你也可以使用 GROUP BY 而不是 DISTINCT
SELECT s.sid
FROM STUDENT s
INNER JOIN ENROLLED_IN e ON e.sid = s.sid
INNER JOIN COURSE c ON c.cid = e.cid AND c.Name = 'Math'
INNER JOIN COURSE c2 ON c2.cid = e.cid AND c2.Name = 'Science'
GROUP BY s.sid
编辑,而不是使用两个联接,您可以使用 HAVING
子句
SELECT s.sid
FROM STUDENT s
INNER JOIN ENROLLED_IN e ON e.sid = s.sid
INNER JOIN COURSE c ON c.cid = e.cid
WHERE c.Name IN ('Math', 'Science')
GROUP BY s.sid
HAVING COUNT(*) = 2
关于mysql - 如何三重连接表以查找和查找匹配两个事物的条目?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18903279/
Redis的事务是什么 Redis 事务的本质是一组命令的集合。事务支持一次执行多个命令,一个事务中所有命令都会被序列化。在事务执行过程,会按照顺序串行化执行队列中的命令,其他客户端提交的命令请求不会
我刚找到这个: a = (None,) print (a is True) print (a is False) print (a == True) print (a == False) print
我尝试将 FCM 与 Android Things 结合使用。我已经导入了 google json,在 list 中进行了更改,将应用程序订阅了主题,但我没有收到推送消息。我唯一得到的是来自服务器的
嘿。我有一个客户端服务器应用程序。服务器监听某个端口,并为每个客户端生成一个管理它的线程。这是基于套接字的,类似于 this但是客户端在 Swing 接口(interface)启动时连接,它会不时调用
您如何通过 ADB for Android Things 截取屏幕截图?我试过了: adb shell screencap -p /sdcard/screen.png adb pull /sdcard
我在理解此代码中的“Callable”时遇到了一些麻烦。我的老师笔记中没有太多细节。 template double averageTime(int iterations, Call
我有一个运行 Android Things 的 Raspberry Pi 3。为简单起见,假设它仅旋转步进电机。 为了再次简化事情,步进电机通过逐个线圈地告诉哪些线圈充电和哪些不充电来旋转。在 Ras
我一直觉得在 WPF 中设计表单布局就像设计网站布局一样。有没有一种工具可以让我直观地设置东西?我主要来自 WinForms 环境,花 2 个小时来布置表单设计并让它不完全按照您想要的方式出现是很烦人
我想在我的应用程序中重用 UITableViewCell,但我收到此错误:在隐式展开可选值时意外发现 nil。 我发现这是因为 UITableViewCell 中的 UI 东西是 nil,所以我的应用
我明天有考试,我想了解线性排序是什么样的,但是当我在谷歌上查找它时,我得到插入排序是一回事吗? 最佳答案 所有 C++ 标准保证的是 std::sort 是 O(N·log(N)。 关于c++ - 在
假设我有一个名为 Poem 的类(class)。 class Poem{ virtual void recite() = 0; } 我有数百个描述子类的 .cpp 和 .hpp 文件,如下所示
我们的主页有我们组织的 JSON-LD。我们的产品页面也应该有那 block 代码吗? 如果 Google 抓取我们的产品页面之一并找到 @type: Organization 和 @type: Pr
我正在使用 PHP 来使用不属于我的服务。该服务返回的内容几乎但不完全不同于 JSON(帽子提示,HGG)。 即,在最简单的形式中,它们看起来像这样 {a: 8531329} 通过json_decod
标题很冗长,可能令人困惑,但我不知道如何让它变得更好......我希望能够访问数组列表中的值并将其打印出来。 我有一个名为 ThingBagInterface 的接口(interface)。这个 Th
我通过调用成功显示了 Android 日期设置: startActivityForResult(new Intent(android.provider.Settings.ACTION_DATE_SET
这个问题在这里已经有了答案: Is there a simpler way to check multiple values against one value in an if-statement
我是一名优秀的程序员,十分优秀!