为什么需要在MySQL select 1 as "number"之后HAVING而不是WHEREMySQL中放置自己创建的列(例如)?
还有没有其他弊端WHERE 1(编写整个定义而不是列名)?
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
为什么需要在HAVING之后放置自己创建的列(例如“ select 1 as number”),而不是在MySQL中放置WHERE?
WHERE被施加之前GROUP BY,HAVING被后应用(并且可以在聚集体筛选)。
在一般情况下,你可以在没有这些条款的引用别名,但MySQL允许引用SELECT在级别别名GROUP BY,ORDER BY和HAVING。
还有什么缺点,而不是做“ WHERE 1”(写整个定义而不是列名)
如果您计算出的表达式不包含任何聚合,则将其放入WHERE子句中可能会更有效率。来源:stack overflow