我必须遵循以下查询:
SELECT * FROM `table1` WHERE `id` IN
(
SELECT `table1_id` FROM `table2` WHERE `id` in
(
SELECT `table2_id` FROM `table3` WHERE `customer_id` = 57
)
)
返回10行(从50开始)
但查询
SELECT `table1_id` FROM `table2` WHERE `id` in
(
SELECT `table2_id` FROM `table3` WHERE `customer_id` = 57
)
返回0行(这是正确的)。
那么为什么我的第一个查询返回几行,而它应该返回0(如子查询)。
如果我使用的customer_id应该在第二个查询中返回行,那么一切都应该如此。
所以我的问题是为什么:
为什么查询返回行而子查询没有?
答案 0 :(得分:1)
这应该是避免在子句
中的相同查询检查结果
SELECT DISTINCT `table1`.*
FROM `table1`
INNER JOIN `table2` ON `table1`.`id` = `table2`.`table1_id`
INNER JOIN `table3` ON `table2`.`id` = `table3`.`table2_id`
and `table3`.`customer_id` = 57