MySQL——sql语句的执行顺序
#核心知识点:
书写顺序:where——》group by——》having——》order by——》limit
许多时候在书写一些复杂的sql语句的时候,尤其是在渐进式推导的时候,经常想要添加一些条件,但是却不知道往哪里加,也许进过许多次尝试之后成功了,但是下次又不知道了,因此总结就显得非常重要了。
首先给出sql语句的查询(或书写)顺序:
(7) SELECT
(8) DISTINCT <select_list> #去重
(1) FROM <left_table>
(3) <join_type> JOIN <right_table> #左、右、内链接的一种
(2) ON <join_condition>
(4) WHERE <where_condition> #条件查询
(5) GROUP BY <group_by_list> #分组
(6) HAVING <having_condition> #分组后过滤
(9) ORDER BY <order_by_condition> #排序
(10) LIMIT <limit_number> #分页
上面从上到下是sql语句的书写顺序,前面括号代表它的执行顺序。
只有弄清楚书写顺序,我们写好的查询语句才不会出现语法错误,
只有弄清楚执行顺序,才能得到想要得到的结果。
关于书写我们要记住关键字:where——》group by——》having——》order by——》limit
下面给出一个例子,帮助理解:
有表table1和table2,需要查询来自杭州,且订单数小于2的客户。
表一:
mysql> select * from table1;
+-------------+----------+
| customer_id | city |
+-------------+----------+
| 163 | hangzhou |
| 9you | shanghai |
| baidu | hangzhou |
| tx | hangzhou |
+-------------+----------+
4 rows in set (0.00 sec)
表二:
mysql> select * from table2;
+----------+-------------+
| order_id | customer_id |
+----------+-------------+
| 1 | 163 |
| 2 | 163 |
| 3 | 9you |
| 4 | 9you |
| 5 | 9you |
| 6 | tx |
| 7 | NULL |
+----------+-------------+
7 rows in set (0.00 sec)
使用两种方法来解答:
第一种,使用子查询
#来自杭州
SELECT * FROM table1 WHERE city = 'hangzhou';
+-------------+----------+
| customer_id | city |
+-------------+----------+
| 163 | hangzhou |
| baidu | hangzhou |
| tx | hangzhou |
+-------------+----------+ #订单小于2
SELECT * FROM table2
GROUP BY customer_id HAVING COUNT(customer_id)< 2; +----------+-------------+
| order_id | customer_id |
+----------+-------------+
| 7 | NULL |
| 6 | tx |
+----------+-------------+
#再过滤掉其中不符合的就行 #联合在一起
SELECT * FROM table2
WHERE customer_id in (SELECT customer_id FROM table1 WHERE city = 'hangzhou')
GROUP BY customer_id HAVING COUNT(customer_id)< 2; #结果:
+----------+-------------+
| order_id | customer_id |
+----------+-------------+
| 6 | tx |
+----------+-------------+
这种方法逻辑性比较鲜明。
2.第二种,使用内链接查询
(1)内链接
mysql> SELECT order_id,a.customer_id city FROM table2 a INNER JOIN table1 b
-> on a.customer_id = b.customer_id;
+----------+------+
| order_id | city |
+----------+------+
| 1 | 163 |
| 2 | 163 |
| 3 | 9you |
| 4 | 9you |
| 5 | 9you |
| 6 | tx |
+----------+------+
(2)地点是杭州
mysql> SELECT order_id,a.customer_id city FROM table2 a INNER JOIN table1 b
-> on a.customer_id = b.customer_id
-> WHERE city = 'hangzhou';
+----------+------+
| order_id | city |
+----------+------+
| 1 | 163 |
| 2 | 163 |
| 6 | tx |
+----------+------+
(3)小于两件
mysql> SELECT order_id,a.customer_id city FROM table2 a INNER JOIN table1 b
-> on a.customer_id = b.customer_id
-> WHERE city = 'hangzhou'
-> GROUP BY a.customer_id
-> HAVING COUNT(1) < 2;
+----------+------+
| order_id | city |
+----------+------+
| 6 | tx |
+----------+------+
使用内链接查询的效率会比子查询来的高,但是对个人的要求比较高。
MySQL——sql语句的执行顺序的更多相关文章
- mysql 中sql语句的执行顺序
今天突然想起来,之前面试一个很牛逼的公司(soho)的时候,一个美眉面试官,面试的时候问到了很多之前都没有意识到的问题,回想起来那美眉看着年纪不大,技术那是真666啊.好了说一下人家问的这个有关mys ...
- SQL语句的执行顺序
一.sql语句的执行顺序 (8)SELECT (9) DISTINCT (11) <TOP_specification> <select_list> (1) FROM < ...
- SQL SERVER 一个SQL语句的执行顺序
一个SQL 语句的执行顺序 1.From (告诉程序 来自哪张表 如果是表表达式 依旧是如此顺序) 2.Where(条件筛选 谓词筛选 ) 3.Group by(分组) 4.Having(分组 ...
- SQL语句的执行顺序和效率
今天上午在开发的过程中,突然遇到一个问题,需要了解SQL语句的执行顺序才能继续,上网上查了一下相关的资料,现整理如下:一.sql语句的执行步骤: 1)语法分析,分析语句的语法是否符合规范,衡量语句中各 ...
- day57-mysql-五种约束和sql语句逻辑执行顺序
二.sql语句逻辑执行顺序 () SELECT () DISTINCT <select_list> 去重复 () FROM <left_table> () <join_t ...
- MySQL笔记-语句的执行顺序
在一次查询线上问题时发现有以下两条同样的SQL,执行后数据的顺序不一样: SELECT * FROM nns_assists_item AS asset WHERE asset.nns_assist_ ...
- mysql查询语句的执行顺序(重点)
一 SELECT语句关键字的定义顺序 SELECT DISTINCT <select_list> FROM <left_table> <join_type> JOI ...
- MySQL Select语句的执行顺序
源文章:How is a query executed in MySQL? 当执行SQL的Select查询语句时,SQL指令的执行顺序如下: FROM 子句 WHERE 子句 GROUP BY 子句 ...
- mysql 查询语句的执行顺序(重重点)
一 SELECT语句关键字的定义顺序 SELECT DISTINCT <select_list> FROM <left_table> <join_type> JOI ...
随机推荐
- IOS7开发~NSAttributedString
从 NSBundle 中读取rtf文本文件的内容,然后用UITextView展示: NSURL *url = [[NSBundle mainBundle] URLForResource:@" ...
- 【Objective-C Runtime动态加载】---动态创建类Class
a.使用objc_allocateClassPair创建一个类Class const char * className = "Calculator"; Class kc ...
- [转]使用Wireshark来检测一次HTTP连接过程
Wireshark是一个类似tcpdump的嗅探软件,界面更人性化一些,今天我用它来检测一次HTTP连接过程. 安装好之后,先配置一下,选择Capture->Options,先设定你要嗅探的网络 ...
- Fatal error: Call to a member function read() on a non-object in
是你的路径出问题了系统 > 系统基本参数 > 站点设置 里面的<站点根网址:和 网页主页链接:>系统 > 系统基本参数 > 核心设置 <DedeCMS安装目录 ...
- void*类型的指针
void*是一种特殊的指针类型,可以用来存放任意对象的地址.一个void*指针存放着一个地址,这一点和其他指针类似.不同的是,我们对它到底储存的是什么对象的地址并不了解: 比如:double a=2. ...
- hdu1708(C++)
这个题目明确说了不涉及大数,假设第i个为b[i]: b[0]=s1; b[1]=s2; b[3]=s1+s2; b[4]=s1+2*s2; b[5]=2*s1+3*s2: b[6]=3*s1+5*s2 ...
- 线段树专题—ZOJ1610 Count the Colors
题意:给一个n,代表n次操作,接下来每次操作表示把[l.r]区间的线段涂成k的颜色当中,l,r,k的范围都是0到8000 分析:事实上就是拿线段树维护一段区间的颜色,整体用到的是线段树的区间更新把,可 ...
- HTML5 Canvas 绘制加拿大枫叶旗
这段代码比较简单,中间的枫叶使用了图片,因为没找到画法: <!DOCTYPE html> <html lang="utf-8"> <meta http ...
- poj 3307 Smart Sister 打表解因子生成数问题
题意: 给i,求由仅以2,3,5,7为因子的数中第i个是多少. 分析: 打表. 代码: //poj 3307 //sep9 #include <iostream> using namesp ...
- Linux中运行c程序,与系统打交道
例一:system系统调用是为了方便调用外部程序,执行完毕后返回调用进程. #include <stdio.h> #include <stdlib.h> main() { pr ...