前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SQL 语句的执行顺序

SQL 语句的执行顺序

作者头像
CoderJed
发布2018-12-28 16:04:46
3.5K0
发布2018-12-28 16:04:46
举报

如下表(table1):

id  client
1   001
1   002
1   003
2   001
2   002
3   001
1   001

id 代表客服人员的 id,client 代表与该客服人员通话的客户的 id,也是说,每有一条记录,就代表一个客服与一位客户进行了通话,相同的记录,例如第一行和第七行,代表着 1 号客服与 001 号客户在不同的时间进行了两次通话,问:如下 SQL 可否统计出与客户通话次数大于 1 客服 id?

SELECT id, COUNT(client) AS count
FROM table1
GROUP BY id
WHERE count > 1;

答案是不能,执行该 SQL 会报错:

[Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE count > 1' at line 4

原因: WHERE 子句会比 SELECT 子句先执行,上面的 SQL 中 ,当 WHERE 子句被执行时,count 这个值尚不存在。直到 WHERE 子句执行完毕,count 才会被计算出来。

SQL 语句的书写顺序如下:

SELECT -> FROM -> WHERE -> GROUP BY -> HAVING -> ORDER BY

SQL 语句的执行顺序如下:

FROM -> WHERE -> GROUP BY -> HAVING -> SELECT -> ORDER BY

其中 SELECT 和 FROM 是必须的,其他关键词是可选的,这六个关键词的执行顺序 与SQL语句的书写顺序并不是一样的,而是按照下面的顺序来执行

  • FROM:需要从哪个数据表检索数据
  • WHERE:过滤表中数据
  • GROUP BY:将上面过滤出的数据分组
  • HAVING:对上面已经分组的数据进行过滤
  • SELECT:查看结果集中的哪个列,或列的计算结果
  • ORDER BY:按照什么样的顺序来查看返回的数据

所以本文开头所说的查询有两种实现的 SQL:

# 使用 HAVING 过滤分组中的数据
SELECT id, COUNT(client) AS count
FROM table1
GROUP BY id
HAVING count > 1;

# 使用内嵌视图(子查询),让 WHERE 可以引用别名
SELECT * FROM 
    (SELECT id, COUNT(client) AS count
    FROM byte_dance_table_1
    GROUP BY id) tmp
WHERE tmp.count > 1;
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.12.25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档