我有以下两个sql表(在mysql中):
Phone_book
+----+------+--------------+
| id | name | phone_number |
+----+------+--------------+
| 1 | John | 111111111111 |
+----+------+--------------+
| 2 | Jane | 222222222222 |
+----+------+--------------+
Call
+----+------+--------------+
| id | date | phone_number |
+----+------+--------------+
| 1 | 0945 | 111111111111 |
+----+------+--------------+
| 2 | 0950 | 222222222222 |
+----+------+--------------+
| 3 | 1045 | 333333333333 |
+----+------+--------------+
我如何找出哪些电话是由 phone_number
不在 Phone_book
? 所需输出为:
Call
+----+------+--------------+
| id | date | phone_number |
+----+------+--------------+
| 3 | 1045 | 333333333333 |
+----+------+--------------+
任何帮助都将不胜感激。
8条答案
按热度按时间jjjwad0x1#
当处理更大的数据集时,下面的代码将比上面给出的答案更有效率。
j2cgzkjk2#
或者,
l7mqbcuq3#
我想
zf2sa74q4#
wooyq4lh5#
e1xvtsh36#
这将返回电话簿表中丢失的额外id。
rmbxnbpk7#
应该删除子查询,允许查询优化程序发挥其魔力。
另外,避免使用“select*”,因为如果有人修改底层的表或视图,它会破坏代码(而且效率很低)。
zqdjd7g98#
有几种不同的方法可以做到这一点,效率各不相同,这取决于您的查询优化程序有多好,以及两个表的相对大小:
这是最短的语句,如果您的电话簿很短,这可能是最快的语句:
或者(感谢alterlife)
或(感谢wopr)
(忽略这一点,正如其他人所说,通常最好只选择所需的列,而不是
*
')