首页 > 数据库 >SQL语句执行顺序,select、from、where、group by、having、order by语句位置及功能详解

SQL语句执行顺序,select、from、where、group by、having、order by语句位置及功能详解

时间:2022-11-28 19:11:06浏览次数:38  
标签:语句 group order SQL where having

在spl语句中的执行顺序:

from→where→group by→having→select→order by

第一步:from语句,选择要操作的表。

第二步:where语句,在from后的表中设置筛选条件,筛选出符合条件的记录。

第三步:group by语句,把筛选出的记录进行分组。

第四步:having语句,设置条件筛选分组后的数据。

第五步:select语句,选取经过上述流程后的结果集。

第六步:order by语句:将select后的结果集按照顺序展示出来。

注意:

掌握SQL语句执行流程非常重要,是理解并写好SQL语句的前提,根据实际业务逻辑要执行的数据库操作对应到SQL语句的执行流程能够帮助我们快速写出相应功能的标准SQL语句。

select:
作用:选取结果集。
位置:位于SQL语句开始。
from:
作用:from后跟要操作的数据表。
数据表形式:单个表、多个并列的表、多个进行join的表。
位置:位于select之后。
where:
作用:设置条件,过滤记录。
位置:位于from之后。
where语句中的运算符:
运算符 描述
= 等于
<> 不等于。注:一些版本中也可为!=。
> 大于
< 小于
>= 大于等于
<= 小于
BETWEEN 在某个范围内
LIKE 匹配某种模式
IN 在多个可能值之中
where语句中的条件类型:
逻辑运算:

AND:且,同时满足多个条件的值。
OR:或,满足多个条件中至少一个即可。
特殊条件:

IS NULL:空值判断。

BETWEEN:在范围之间的值。
IN:在多个可能值之中。
LIKE:模糊查询。
group by:
作用:用于结合结合聚合函数,感觉一个列或多个列对结果集进行分组。
位置:一般位于where后或者SQL语句末尾位置。
having:
作用:筛选分组后的各组数据,一般和聚合函数结合使用。
位置:一般位于SQL语句末尾。
常用聚合函数:

函数 作用
sum(列名) 求和
max(列名) 最大值
min(列名) 最小值
avg(列名) 平均值
first(列名) 第一条记录
last(列名) 最后一条记录
count(列名) 统计记录数 注:count(*)为统计所有记录数
order by:
作用:用于对结果集按照一个或者多个列进行排序。
位置:一般位于SQL语句末尾。
排序:

默认按照升序对记录进行排序,如果按照降序对记录进行排序,需加DESC关键字。
order by多列时,先按照第一个column_name排序,再按照第二个column_name排序。
排序实例:

order by A # A升序排列
order by A desc,B # A 降序(优先),B 升序排列
order by A ,B desc # A 升序(优先),B 降序排列
where和having区别:
where在group by前, having在group by 之后。
where中不能使用聚合函数,having中可以使用聚合函数。原因:因为聚合函数是针对结果集进行的,但where是在查询结果集之前进行,故where中不能使用聚合函数;having是针对结果集做筛选的,故一般把聚合函数放在having中。


标签:语句,group,order,SQL,where,having
From: https://www.cnblogs.com/mmds/p/16933072.html

相关文章

  • Android开发使用MediaRecorder进行录音
    在说手机android开发如何使用MediaRecorder进行录音前,我先来说一下如何在手机SD卡或手机内存上定义路径吧(优先存储在SD卡上)。//获取存放图片或录音文件的路径(手机内存上或......
  • 基于Bootstrap使用jQuery实现输入框组input-group的添加与删除-改进版
          上一次说到了​​基于Bootstrap使用jQuery实现输入框组input-group的添加与删除​​ ,初始状态下只有一个输入框组,可以通过点击输入框组的右侧“+”(或自定......
  • mysql基础语句
       一、mysql中6中常见的的约束/规则主键约束(primarykey)外键约束(foreignkey):如果同一个属性字段x在表一中数主键,而在表二中不是主主键,则字段称为表二的外键。非......
  • SQL语句查询关键字
    SQL语句查询关键字前戏SQL语句中关键字的执行顺序和编写顺序并不是一致的,可能会错乱eg:selectid,namefromuserinfo;我们先写的select再写的from,但是执行的时候是先......
  • 1 swich语句
    #define_CRT_SECURE_NO_WARNINGS #include<stdio.h>intmain(){ intday=0; printf("请输入数字\n"); scanf("%d",&day); switch(day) { case1: case2: ......
  • 初始SQL万能语句 ' or 1=1#
    使用SQL注入前在日常界面用户登录过程中通常是这样的输入用户名“username”输入密码“password”SQL注入语句编写如下$sql=select*formuserwhereusername='user......
  • 进入python的世界_day39_数据库——编辑表的补充、SQL数据查询语句
    一、编辑表的SQL语句补充altertable旧表名rename新表名;——改表名altertable表名change旧字段新字段新字段数据类型;——改字段altertable表名add新字......
  • SQL语句查询关键字前期数据准备
    前期数据准备createtableemp(idintprimarykeyauto_increment,namevarchar(20)notnull,genderenum('male','female')notnulldefault'male',#大部......
  • MYSQL SQL语句查询关键字
    首先先创建一组数据createtableemp(idintprimarykeyauto_increment,namevarchar(20)notnull,genderenum('male','female')notnulldefault'male',......
  • Java开发学习(四十四)----MyBatisPlus查询语句之查询条件
    1、查询条件前面我们只使用了lt()和gt(),除了这两个方法外,MybatisPlus还封装了很多条件对应的方法。MybatisPlus的查询条件有很多:范围匹配(>、=、between)模糊匹......