作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
下面的查询可以优化吗?可以创建哪些索引?
SELECT column_a
FROM Table_b
JOIN Table_a
WHERE Table_B.ID_b = Table_A.ID_a
OR Table_B.ID_b = Table_A.ID_b;
最佳答案
您的查询实际上应该是:
SELECT column_a
FROM Table_b
JOIN Table_a ON Table_B.ID_b IN (Table_A.ID_a, Table_A.ID_b)
如果您没有为 JOIN 提供 ON 标准,MySQL 会将其视为CROSS JOIN
——结果是笛卡尔积(这很糟糕,除非这确实是您想要的)。如果我知道 column_a
来自哪个表,我可能会建议采用不同的查询方法...
索引以下内容:
TABLE_A 中的两列可以是覆盖索引,而不是单独的索引。
关于带有 OR 优化的 mysql 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5960356/
我是一名优秀的程序员,十分优秀!