作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我必须进行以下查询:
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,一切都会按原样进行。
所以我的问题是为什么这样做:
为什么查询返回行而子查询不返回行?
最佳答案
这应该是相同的查询,避免使用 in 子句
检查结果
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
关于mysql - SELECT IN 带有空子查询,给出奇怪的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44850027/
我是一名优秀的程序员,十分优秀!