sql advantage 执行sql_SQL执行顺序

小贴士

SQL在执行顺序中最先执行的是FROM操作,最后执行lIMIT;在执行每一个操作的时候都会产生一张虚拟的表,但执行过程中产生的表不会对用户展示,只有最后一张表作为输出结果呈现给用户。

SQL执行过程

1.FROM     :对FROM左边的表和右边的表计算笛卡尔积,产生虚拟表t1
2.ON       :对表t1进行ON筛选,只有符合条件的行才会记录在表t2中
3.JOIN     :如果指定了OUTER JOIN(如:left join、right join),那么未匹配到的行作为外部行添加到表t3中
4.WHERE    :对表t3进行where条件过滤,只有符合条件的记录才会记录在表t4中
5.GROUP BY:根据group by 子句中的列,对表t4记录进行分组操作,产生表t5
6.HAVING   :对表t5进行having过滤,只有符合条件的行才会记录在表t6中
7.SELECT   :执行select操作,选择指定的列,产生表t7
8.DISTINCT :对表t7记录进行去重,产生表t8
9.ORDER BY :对表t8记录进行排序,产生表t9
10.LIMIT   :取出指定的行,产生表t10,并将结果进行展示

笛卡尔积:

两个集合R和S的笛卡尔积可表示为:RxS;第一个对象是R的成员而第二个对象是S的所有可能有序对的其中一个成员,如下图:

ff702eebe0a40863ceac131e305c4a16.png
图片网络,违者必删
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值