SELECT IN 与空子查询,给出奇怪的结果

鸭子爵士

我必须遵循以下查询:

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,一切都会按原样进行。

所以我的问题是为什么要这样做:
为什么查询返回行而子查询不返回?

scaisEdge

这应该是在子句中避免的相同查询

检查结果

  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

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章