mysql命令书写顺序_MySQL SQL语句书写顺序和执行顺序

SQL语句书写顺序和执行顺序

(7) SELECT

(8) DISTINCT

(1) FROM

(3) JOIN

(2) ON

(4) WHERE

(5) GROUP BY

(6) HAVING

(9) ORDER BY

(10) LIMIT

书写顺序从上向下依次书写,即:

SELECT →FROM → JOIN → ON → WHERE → GROUP BY → HAVING → ORDER BY→ LIMIT

而执行顺序按照左侧编号进行。即:

FROM → ON → JOIN → WHERE → GROUP BY → HAVING → SELECT →DISTINCT → ORDER BY→ LIMIT

MySql执行顺序理解

加载 from关键词后面跟的表,计算笛卡尔积,生成虚拟表vt1。这也是sql执行的第一步:表示要从数据库中执行哪些表。

筛选关联表中满足on表达式的数据,保留主表数据,并生成虚拟表vt2。join表示要关联的表,on代表连接条件。

如果使用的是外连接,执行on的时候,会将主表中不符合on条件的数据也加载进来,作为外部行。

如果from子句中涉及多张表,则重复第一步到第三步,直至所有的表都加载完毕,更新vt3。

执行where表达式,筛选出符合条件的数据生成vt4。

执行 group by 子句进行分组。分组会把子句组合成唯一值并且每个唯一值只包含一行,生成vt5。一旦执行group by,后面的所有步骤只能操作vt5中的列(group by的子句包含的列)和聚合函数。

温馨提示:这一步开始才可以使用select中的别名,它返回的是一个游标,而不是一张表,所以在where中不可以使用select中的别名,而having却可以。

执行聚合函数,例如sum、avg等,生成vt6。

执行having表达式,筛选vt6中的数据。having是唯一一个可以在分组后执行的条件筛选表达式,生成vt7。

执行SELECT,从vt7中筛选列,生成vt8。

执行distinct,对vt8去重,生成vt9。

其实执行过group by后就没必要再去执行distinct,因为分组后,每组只会有一条数据,并且每条数据都不相同。

按照order_by_condition 对vt9进行排序,此处亦可以使用别名。这个过程比较耗费资源。

执行 limit 语句,取出指定条数的结果集返回给客户端。

实例

select g.student_id, sum(成绩) as sum成绩

from t_grade g INNER JOIN t_student s on g.student_id = s.id

where s.clasz = '高一1班'

group by g.student_id

having sum成绩 > 600

order by sum成绩

在上面的MySQL代码示例中,SQL 语句的执行顺序如下:

首先执行 FROM 子句, 从表 t_grade 和 t_student 组装数据源的数据,执行一个笛卡尔乘积,此时生成虚拟表 vt1。

接下来便是应用on筛选器,on 中的逻辑表达式将应用到 vt1 中的各个行,筛选出满足 on 逻辑表达式的结果集,生成虚拟表 vt2。

由于是 inner join,故把两张表过滤的行添加进来,生成虚拟表vt3。

执行 WHERE 子句, 筛选 vt3中高一1班所有数据。

执行 GROUP BY 子句, 按 student_id 列进行分组。

温馨提示:这一步开始才可以使用select中的别名,它返回的是一个游标,而不是一张表,所以在where中不可以使用select中的别名,而having却可以。

使用聚合函数 sum() 计算各位同学的总成绩。

执行 HAVING 子句, 筛选课程总成绩大于 600 分的学生。

知识扩展

on和where的区别

简单地说,当有外关联表时,on主要是针对外关联表进行筛选,主表保留;当不是外关联表时,二者作用相同。例如在左外连时,首先执行on,筛选掉外连表中不符合on表达式的数据,而where的筛选是对on关联后的结果集进行筛选。

limit 分页

若每页显示条目数记为pageSize,显示的页数记为page,则有:

SELECT * FROM table_name LIMIT (page-1)* pageSize, pageSize

结束语

了解了MySQL中SQL的执行顺序,对我们开发者大有裨益,可以写出更健壮的代码。

本文总结了mysql的书写顺序和执行顺序,理解这些有助于优化sql语句,有助于掌握 MySQL 中的 sql 语句从写出来到最终执行的轨迹,有助于深入和细致的认识 sql,提高数据库理解能力。同时,对于复杂sql的执行过程、编写都会有一定程度的意义。

以上就是这篇文章的全部内容了,希望本文对大家的学习或者工作具有一定的参考和学习价值;如果有疑问,大家可以在评论区留言交流,也希望大家多多点赞关注。谢谢大家对楼兰的胡杨的支持!

Reference

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/438656.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

22桥接模式(Bridge Pattern)

动机(Motivate): 在软件系统中,某些类型由于自身的逻辑,它具有两个或多个维度的变化,那么如何应对这种“多维度的变化”?如何利用面向对象的技术来使得该类型能够轻松的沿着多个方向进行变化,而又不引入额外的复杂度…

mysql动静分离_haproxy的web服务负载均衡、动静分离、 MySQL服务负载均衡、状态监控...

实验环境:基于centos6.6haproxy-Server:172.16.249.98 hostname:node1upsteram server1:172.16.249.100 hostname:node2upstream server2:172.16.249.99 hostname:node3web服务的负载均衡以及状态监控:设置记录hapro…

24组合模式(Composite Pattern)

动机(Motivate): 组合模式有时候又叫做部分-整体模式,它使我们树型结构的问题中,模糊了简单元素和复杂元素的概念,客户程序可以向处理简单元素一样来处理复杂元素,从而使得客户程序与复杂元素的内部结构解耦。意图(Intent): 将对象组合…

mysql二进制日志被删除无法启动_mysql二进制日志文件出错导致mysql服务无法启动...

今天打开phpmyadmin发现连不上mysql数据库,重启mysql启动不起来,查看日志发现如下错误mysqld: File .\mysql-bin.000370 not found (Errcode: 2)141120 13:23:13 [ERROR] Failed to open log (file .\mysql-bin.000370, errno 2)141120 13:23:13 [ERROR]…

kafka mysql事务_【干货】Kafka 事务特性分析

特性背景消息事务是指一系列的生产、消费操作可以要么都完成,要么都失败,类似数据库的事务。这个特性在0.10.2的版本是不支持的,从0.11版本开始才支持。华为云DMS率先提供Kafka 1.1.0的专享版服务,支持消息事务特性。支持事务消息…

23装饰模式(Decorator Pattern)

子类复子类,子类何其多 假如我们需要为游戏中开发一种坦克,除了各种不同型号的坦克外,我们还希望在不同场合中为其增加以下一种或多种功能;比如红外线夜视功能,比如水陆两栖功能,比如卫星定位功能等等。 按类继承的作法…

gb2312编码在线转换_python基础学习—04字符串与编码

点击上方蓝字关注我们不迷路!字符串与编码一、了解计算机编码1.1 编码定义:将信息从一种形式转换为另外一种形式的过程叫做编码,即信息转换过程举例:信息加密解密、语言翻译1.2 计算机编码定义:将计算机可读信息转换…

25外观模式(Facade Pattern)

动机(Motivate): 在软件开发系统中,客户程序经常会与复杂系统的内部子系统之间产生耦合,而导致客户程序随着子系统的变化而变化。那么如何简化客户程序与子系统之间的交互接口?如何将复杂系统的内部子系统与客户程序之间的依赖解耦&#…

mysql mybatis类型对应_Mybatis与数据库的类型对应

Mybatis与数据库的类型对应由于业务的改变,在首次存入数据库时某些int属性并没有赋值,于是默认值就开始污染数据库了。java实体属性对应mysql和SQL Server 和Oracle 数据类型对应1:Java数据类型与MySql数据类型对照表*对于bolb,一…

26享元模式(Flyweight Pattern)

面向对象的代价 面向对象很好地解决了系统抽象性的问题,同时在大多数情况下,也不会损及系统的性能。但是,在 某些特殊的应用中下,由于对象的数量太大,采用面向对象会给系统带来难以承受的内存开销。比如: 图形应用…

mysql一个事务多个log_MySQL识别一个binlog中的一个事物

MySQL测试版本5.7.14设置GTID_MODEONON(3): Both new and replicated transactions must be GTID transactions(生成的是GTID事物,slave也只能应用GTID事物)设置binlog格式为row模式做如下操作mysql> insert into test values(1,2);Query OK, 1 row affected (0.…

go for 循环遍历数组并排序_10. Go语言流程控制:for 循环

本文原文:http://golang.iswbm.comGithub:http://github.com/iswbm/GolangCodingTimeGo里的流程控制方法还是挺丰富,整理了下有如下这么多种:if - else 条件语句switch - case 选择语句for - range 循环语句goto 无条件跳转语句de…

27代理模式(Proxy Pattern)

直接与间接: 人们对复杂的软件系统常有一种处理手法,即增加一层间接层,从而对系统获得一种更为灵活、 满足特定需求的解决方案。 …

mysql设计资源目录售卖_MySQL目录设计一些策略_mysql

前言索引加快了检索的速度,但是却降低了数据列里插入、删除以及修改数值的速度。也就是说,索引降低了许多涉及写入的操作速度。之所以出现这种情况,是由于写入一条数据不仅仅是要写入到数据行,还需要所有的索引都作出相应的改变如…

31模板方法(Template Method)

无处不在的Template Method 如果你只想掌握一种设计模式,那么它就是Template Method! 动机(Motivate): 变化 -----是软件设计的永恒主题,如何管理变化带来的复杂性?设计模式的艺术性和复杂度就在于如何 分析,并发现系统中…

bat 脚本清空窗口内容_tomcat9.0启动脚本startup.bat的分析

1、 Apache Tomcat的下载和安装从Apache官网https://tomcat.apache.org/可以下载各种版本的tomcat软件,下载的文件格式可以是zip/tar.gz/exe形式的。如下图所示,在64位windows中使用tomcat,我们可以下载"64-bit Windows.zip",直接解…

33迭代器模式(Iterator Pattern)

动机(Motivate): 在软件构建过程中,集合对象内部结构常常变化各异。但对于这些集合对象,我们希望在不暴露其内部结构的同时,可以让外部客户代码透明地访问其中包含的元素;同时这种“透明遍历”也为“ 同一种算法在多种集合对象上进行操作…

MySQL什么是关系_MySQL教程-关系模型

MySQL教程-关系模型Date 2021-1-22Author Haihan Gao什么是关系模型关系模型本质上就是多个存储数据的二维表表的每一行称为记录记录是一个逻辑意义上的数据表的每一列称为字段。同一个表每一行记录拥有若干相同字段字段定义数据类型:INT,BIGINT,DOUBLE是否允许为NU…

32命令模式(Command Pattern)

耦合与变化: 耦合是软件不能抵御变化灾难的根本性原因。不仅实体对象与实体对象之间存在耦合关系,实体对象与行为操作之间也存在耦合关系。 动机(Mot…

mysql 事务实例_mysql实现事务的提交和回滚实例

mysql创建存储过程的官方语法为:复制代码 代码如下:START TRANSACTION | BEGIN [WORK]COMMIT [WORK] [AND [NO] CHAIN] [[NO] RELEASE]ROLLBACK [WORK] [AND [NO] CHAIN] [[NO] RELEASE]SET AUTOCOMMIT {0 | 1}我这里要说明的mysql事务处理多个SQL语句的回滚情况。…