MySQL数据库之单表查询中关键字的执行顺序
MySQL数据库之单表查询中关键字的执行顺序
1 语法顺序
select
distinct
from
where
group by
having
order by
limit
2 执行顺序
from #step1 确定在哪张表做查询
where #step2 设置过滤条件,过滤出符合条件的内容
group by #step3 对过滤后的数据按字段分组
having #step4 再进一步对分组后的数据过滤
select #step5 查找数据
distinct #step6 去重
order by #step7 对去重后的数据按要求排序
limit #step8 限制显示或打印数据的条数
1、正确且高效地查询数据的前提是:明确这些关键字的使用语法、语法顺序、执行顺序
2、语法顺序、执行顺序都是固定不能改变的,我们要按照MySQL的规则来使用
3、关键字的知识点较多且繁琐,需要我们灵活使用。
3 关键字使用语法
3.1 from
1、统计分析表中数据,第一步肯定是确定被统计的是那张表,使用关键字from,意为从该表中查数据
#示例
select * from student; #从student表中查所有字段的数据
3.2 where
1、where使用在分组前,目的是过滤出需要统计待分析的那些数据
2、where在分组前,不能使用聚合函数,可以使用任意字段过滤
3、where可以使用的过滤条件包括:
- 比较运算符,><>= <= <> !=
- between and in 等关键字
- 逻辑运算符,and or not
- 模糊查询,like "pattren" , pattern 中有%表示任意读个字符,_表示一个字符
- 正则表达式 regexp
#示例
from student where sname="jack"; #过滤出姓名为"jack"的学生
from student where sid>20; #过滤出学号大于20的学生们
from student where sid between 10 and 20; #过滤出学号在10-20之间的学生们
from student where sid in (2,5,8); #过滤出学号为2或者5或者8的学生
from student where sid >10 and sscore >90; #过滤出学号大于10且分数大于90分的学生
from student where sname like "刘%"; #过滤出姓刘的学生们
from student where sname regexp "^刘"; #"刘"开头的,即姓刘的学生
3.3 group by
1、分组再where之后,是对过滤出来的数据再按要求的字段分组
2、group by 分组的目的是为了统计分析每个组内的数据信息,如班级人数,每个班级的平均分、男女人数等
3、分组后,只能使用分组字段、如果需要查看组内信息需要使用聚合函数
4、group by 还可以和group_concat()一块使用,查看组内成员信息
5、如果不适用group by,默认这张表示一个组
#示例
select class_name, count(sid) from student group by class_name;
select class_name,group_concat(sname) from student group by class_name;
3.4 having
1、having也是过滤的作用,但having用在分组后,是过滤组级别的
2、having与where不同,having只能使用分组字段或者是聚合函数,不能使用其他字段
3、where使用的那些过滤方式,having 也适用
#示例
select class_id,count(sid) from student group by class_id having class_id >10;
select class_id,count(sid) from student group by class_id having avg(score)>60;
3.5 select
1、select是选择数据的意思,后面直接更想要显示的数据字段,可以用聚合函数,如果是* 代表所有字段
3.6 distinct
1、distinct 去重的功能
#示例
select distinct course_name from student group by course_name;
#目的是统计有个不同的班级,因为存在不同的学生在一个班级,不使用distinct显示不美观
3.7 order by
1、order by 是对上述确定的数据做排序,分升序和降序两种
2、默认升序排列
#示例
select * from student order by sid asc; #学号升序排列,此时可省略关键字 asc
select *from student order by score desc; #分数降序排列
3.8 limit
1、限制查询的记录数
2、limit后面直接跟一个数字n,表示显示n条记录
3、limit后面分别跟两个数字n1,n2,表示从n1位置开始,显示n1位置后面的n2条记录
#示例
select sid from student limit 5; #显示5条记录,sid分别为:1\2\3\4\5
select sid from student limit 0,5; #显示5条记录,sid分别为:1\2\3\4\5,默认从0开始
select sid from student limit 1,5; #显示5条记录,sid分别为:2\3\4\5\6
MySQL数据库之单表查询中关键字的执行顺序的更多相关文章
- MySQL数据库语法-单表查询练习
MySQL数据库语法-单表查询练习 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客主要是对聚合函数和分组的练习. 一.数据表和测试数据准备 /* @author :yinz ...
- mysql数据库之单表查询多表查询
单表查询 前期表准备 create table emp( id int not null unique auto_increment, name varchar(20) not null, sex e ...
- mysql数据库之单表查询
单标查询 单表查询语句 关键字执行的优先级 简单查询 where约束 group by 聚合函数 HAVING过滤 order by 查询排序 LIMIT限制查询的记录数 使用正则表达式查询 单表查询 ...
- SQL查询中关键字的执行顺序
SQL语句中的每个关键字都按照顺序往下执行,而每一步操作会生成一个临时表,最后的临时表就是最终结果: FROM <left_table>:from子句返回初始结果集 <join_ty ...
- mysql 基础入门 单表查询
单表查询 select 表头,表头 as 别名 ,表头(+-*/的运算) from table_a 1.条件查询 where + 条件 <> , != 不等于 = 等于,也可以表示字符串值 ...
- MySQL数据库语法-多表查询练习一
MySQL数据库语法-多表查询练习一 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客主要介绍的多表查询的外键约束,以及如何使用外链接和内连接查询数据信息. 一.数据表和测试 ...
- mysql 数据操作 单表查询 目录
mysql 数据操作 单表查询 mysql 数据操作 单表查询 简单查询 避免重复DISTINCT mysql 数据操作 单表查询 通过四则运算查询 mysql 数据操作 单表查询 concat()函 ...
- mysql 数据操作 单表查询 where 约束 目录
mysql 数据操作 单表查询 where约束 between and or mysql 数据操作 单表查询 where约束 is null in mysql 数据操作 单表查询 where约束 li ...
- mysql 数据操作 单表查询 group by 分组 目录
mysql 数据操作 单表查询 group by 介绍 mysql 数据操作 单表查询 group by 聚合函数 mysql 数据操作 单表查询 group by 聚合函数 没有group by情况 ...
随机推荐
- VMware里装XP 没有找到硬盘驱动器
遇到问题: 解决:要给虚拟机配上一个虚拟的硬盘驱动器.在VMWare的虚拟机配置里面给这个虚拟机增加硬盘,选IDE模式,而非SCSI,设定硬盘大小和文件名就可以了.
- vue教程(三)-slot\keep-alive的使用
一.slot其实就是填坑操作,父组件传递dom结构,是vue提供的一种内置组件(组件知识请查看上篇博客内容) 写法:<slot></slot> 例子: var child = ...
- python UUID
UUID介绍 UUID是128位的全局唯一标识符,通常由32字节的字符串表示.它可以保证时间和空间的唯一性,也称为GUID,全称为:UUID ―― Universally Unique IDentif ...
- JAVA 基于TCP协议的一对一,一对多文件传输实现
最近老师给我们上了多线程和TCP和UDP协议,其中一个要求就是我们用JAVA协议一个基于TCP和UDP这两种协议的一对一文件上传和一对多文件上传. 然后我就开始分析TCP和UDP这两个协议的特点,发现 ...
- IDEA创建普通java和web项目教程
1.第一个javaSE项目 01.双击idea运行IDE 02.配置JDK 03.创建项目的workspace .iml文件里面是当前项目的一些配置信息! 相当于web项目中的web.xml文件 04 ...
- 一、PyTorch 入门实战—Tensor(转)
目录 一.Tensor的创建和使用 二.Tensor放到GPU上执行 三.Tensor总结 一.Tensor的创建和使用 1.概念和TensorFlow的是基本一致的,只是代码编写格式的不同.我们声明 ...
- Linux升级GCC
升级原因 测试需要使用DOClever,下载了最新的node8.11,运行node 时候报错 [root@app_test bin]# node www module.js:681 return pr ...
- 抓取崩溃的log日志
1.下载adb工具包 也就是解锁软件,如果要解锁的话,需确认有fastboot 安装jdk.sdk 2.注意事项 请确保电脑上只连接了一台手机设备(最好只连接一条USB线),同时确保手机已开启USB调 ...
- poj 1050 To the Max(最大子矩阵之和)
http://poj.org/problem?id=1050 我们已经知道求最大子段和的dp算法 参考here 也可参考编程之美有关最大子矩阵和部分. 然后将这个扩大到二维就是这道题.顺便说一下,有 ...
- 实时同步lsyncd
实时同步lsyncd 1 lsyncd 1.1 lsyncd 简介 Lsyncd使用文件系统事件接口(inotify或fsevents)来监视对本地文件和目录的更改.Lsyncd将这些事件整理几秒钟, ...