我正在尝试使用 LEFT JOINS 查找不同的孤立 menu_item 记录,然后检查 NULL 值。
下面的查询返回实际上不是孤立的结果。mitem_id 是 menu_item 表的主键和 price_info 表的外键。pinfo_id 是 price_info 表和外键 orderdetails 表的主键。
SELECT DISTINCT mi.mitem_id, descr
FROM menu_item mi
LEFT JOIN price_info pi ON pi.menu_item = mi.mitem_id
LEFT JOIN orderdetails od ON od.price_info = pi.pinfo_id
WHERE od.detail_id IS NULL;
返回的记录之一如下所示:
+----------+------------------+
| mitem_id | descr |
+----------+------------------+
| 926 | Alameda Pale Ale |
+----------+------------------+
我怎么知道它不是孤儿是因为当我运行查询时:
SELECT od.detail_id
FROM orderdetails od
INNER JOIN price_info pi ON pi.pinfo_id = od.price_info
INNER JOIN menu_item mi ON mi.mitem_id = pi.menu_item
WHERE mi.mitem_id = 926;
它返回一组记录:
+-----------+
| detail_id |
+-----------+
| 142830 |
| 142876 |
| 143394 |
| 143610 |
为什么它返回的结果不是孤立的?