【③MySQL 数据查询】:提高查询的效率

这篇具有很好参考价值的文章主要介绍了【③MySQL 数据查询】:提高查询的效率。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

欢迎来到小K的MySQL专栏,本节将为大家带来MySQL数据查询的讲解(基本、分组、排序、聚合、分页、条件查询)


一、基本查询

MySQL数据库使用SELECT语句来查询数据

1、查询多个字段

以下为MySQL数据库中查询数据通用的SELECT语法:

SELECT 字段名,字段名... FROM 表名;
SELECT * FROM 表名; #查询所有字段
  • 查询语句中可以使用一个或者多个表,表之间使用逗号(,)分隔,并使用WHERE语句来设定查询条件
  • SELECT命令可以读取一条或者多条记录
  • 你可以使用星号( * )来替代其它字段,SELECT语句会返回表的所有字段数据

2、设置别名

SELECT 字段1 [AS 别名],字段2 [AS 别名]... FROM 表名;

3、去除重复记录

SELECT DISTINCT 字段列表 FROM 表名;

4、四则运算查询

运算符 描述
+ 加法
- 减法
* 乘法
/(DIV) 除法
%(MOD) 求余

5、基本查询练习

  1. 查询指定字段 ename,job,sal的数据
SELECT ename,job,sal FROM emp;
  1. 查询所有字段,建议不要写 * ——不直观 影响效率 遵循开发规范最好不要写* 把所有字段写出了,一目了然
SELECT * FROM emp;

SELECT empno,ename,job,mgr,hiredate,sal,comm,deptno FROM emp;
  1. 查询所有员工的职位,并起别名
SELECT job AS '工作' FROM emp;
SELECT job '工作' FROM emp;   # as 可以省略
  1. 查询员工的的职位有哪些(不要重复)
SELECT DISTINCT job FROM emp;
  1. 查询员工年薪 即 sal* 12
SELECT ename AS '姓名',sal AS '月薪',sal*12 AS '年薪' FROM emp;

效果如下
【③MySQL 数据查询】:提高查询的效率
【③MySQL 数据查询】:提高查询的效率

二、条件查询

我们知道从 MySQL 表中使用 SELECT 语句来查询数据,如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中。

语法

SELECT 字段名 FROM 表名 WHERE 条件;

运算符表

关系运算符 功能
> 大于
>= 大于等于
< 小于
<= 小于等于
= 等于
<> 或 != 不等于
逻辑运算符 功能
AND 或 && 并且(多个条件同时成立)
OR 或 || 或者(多个条件任意成立一个)
NOT 或 ! 非,不是
其他 功能
BETWEEN…AND… 在某个范围之间(含最小、最大值)
IN(…) 在in之后的列表中的值,多选一
LIKE 模糊匹配(_匹配单个字符,%匹配任意个字符)
IS [NOT] NULL 是 NULL

条件查询练习

  1. 查询工资等于3000的员工
SELECT ename,sal FROM emp WHERE sal=3000;
  1. 查询工资小于1000的员工
SELECT ename,sal FROM emp WHERE sal<1000;
  1. 查询工资小于等于1000的员工
SELECT ename,sal FROM emp WHERE sal<=1000;
  1. 查询没有奖金的员工
SELECT * FROM emp WHERE comm is NULL;
  1. 查询有奖金的员工
SELECT * FROM emp WHERE comm is NOT NULL;
  1. 查询工资在1200到1800之间的员工(包含1200和1800)
SELECT *FROM emp WHERE sal>=1200 && sal<=1800;
SELECT *FROM emp WHERE sal BETWEEN 1200 AND 1800;
  1. 查询职位为推销员,且工资小于1500的员工
SELECT * FROM emp WHERE job='salesman'&& sal<1500;
  1. 查询工资为800 或 3000 或 5000的员工
SELECT * FROM emp WHERE sal in(800,3000,5000);
  1. 查询姓名为四个字的员工
SELECT * FROM emp WHERE ename LIKE '____';
  1. 查询姓名最后一位是S的员工
SELECT * FROM emp WHERE ename LIKE '%s';

效果如下

【③MySQL 数据查询】:提高查询的效率
【③MySQL 数据查询】:提高查询的效率
【③MySQL 数据查询】:提高查询的效率

三、聚合函数(统计函数)

SQL允许对表中的数据进行计算,将一列数据作为一个整体,进行纵向计算

函数名 作用
MAX(column) 返回某列的最高值(没有则返回NULL)
MIN(column) 返回某列的最低值(没有则返回NULL)
COUNT(column) 返回某列的行数(不包括 NULL 值)
COUNT(*) 返回被选列行数(包括NULL)
SUM(column) 求和
AVG(column) 求平均值

其中COUNT函数可用于任何数据类型(因为它只是计数),而SUMAVG函数只能对数值类型做计算,MAXMIN可用于数值、字符串或是日期时间数据类型

聚合函数练习

  1. 统计该企业员工数量
SELECT COUNT(*) FROM emp;
SELECT COUNT(comm) FROM emp;
SELECT COUNT(mgr) FROM emp;
  1. 统计该企业员工的平均工资
SELECT AVG(sal) FROM emp;
  1. 查询该企业员工的最高工资
SELECT MAX(sal) FROM emp;
  1. 查询该企业员工的最低工资
SELECT MIN(sal) FROM emp;
  1. 计算所有销售的工资之和
SELECT SUM(sal) as '销售总工资' FROM emp WHERE job='salesman';

效果如下

【③MySQL 数据查询】:提高查询的效率

四、分组查询

需要声明一点的是,虽然说统计函数一般是搭配分组查询,但是单独使用的情况一定是有的。例如:在做报表显示的时候基本的分页操作,一定要查询出全部的数据

那么什么是分组呢?

分组这个概念在生活中其实是很常见的,比如有以下需求:

  • 1.在一个班级之中,要求男女各一组进行辩论赛
  • 2.在公司中,要求每个部门一组进行拔河比赛

对于第一个需求,假设存在学生表,那么在学生表之中一定会存在一个性别字段,性别只可能是男或者女。
而在公司之中,如果要进行部门分组,肯定需要一个部门列的内容存在重复。

分组只对数据有重复的字段才有意义,我们可以查看emp表,找到可以分组的字段job 和 deptno。

语法

SELECT 分组字段/聚合函数 FROM 表名 [WHERE 条件] GROUP BY 分组字段 [HAVING 分组后条件];

分组查询练习:

  1. 统计出每个工作岗位的人数
SELECT job,COUNT(*) '总人数' FROM emp GROUP BY job;
  1. 统计出每种职位的最低和最高工资
SELECT job,MAX(sal),MIN(sal) FROM emp GROUP BY job;

以上两个查询就实现了分组的基本操作,而且这些代码都按照标准格式进行了编写。可是在分组之中,个人认为最麻烦的地方就是在于分组操作的若干限制。

注意事项:

  1. 如果一个查询之中不存在GROUP BY子句,那么SELECT 子句之中只允许出现统计函数,其它任何字段都不允许出现

    #错误的语句
    SELECT ename,COUNT(job) FROM emp;
    #正确的语句
    SELECT COUNT(job) FROM emp;
    
  2. 在统计查询之中(存在GROUP BY子句),SELECT子句之中只允许出现分组字段(GROUP BY之后定义的字段和统计函数),其他的任何字段都不允许出现

    #错误的语句
    SELECT ename,COUNT(job) FROM emp GROUP BY job;
    #正确的语句
    SELECT job,COUNT(job) FROM emp GROUP BY job;
    

    在以后进行分组操作的时候,本着一个原则:GROUP BY子句之中允许出现的字段才是SELECT子句中允许出现的字段。

HAVING查询练习

  1. 显示不同职位薪资少于1500的人数
SELECT job,COUNT(*) FROM emp WHERE sal<1500 GROUP BY job HAVING COUNT(*)>3;
  1. 显示非销售人员(salesman)工作名称以及从事同一工作的员工的月工资的总和,并且要满足从事同一工作的员工的月工资合计大于等于5000
SELECT job,SUM(sal) '月薪' FROM emp WHERE job!='salesman' GROUP BY job HAVING SUM(sal)>=5000;

效果如下:
【③MySQL 数据查询】:提高查询的效率

WHEREHAVING区别

  • WHERE是在分组之前使用(可以没有GROUP BY),不允许使用统计函数;
  • HAVING是在分组之后使用(必须结合GROUP BY),允许使用统计函数。

【③MySQL 数据查询】:提高查询的效率

五、排序查询

通过条件查询语句可以查询到符合用户需求的数据,但是查询到的数据一般都是按照数据最初被添加到表中的顺序来显示。为了使查询结果的顺序满足用户的要求,MySQL 提供了 ORDER BY关键字来对查询结果进行排序。

在实际应用中经常需要对查询结果进行排序,比如,在网上购物时,可以将商品按照价格进行排序;在医院的挂号系统中,可以安装挂号的先后顺序进行排序…

语法:

SELECT 字段名 FROM 表名 ... ORDER BY 排序字段名[ASC|DESC],排序字段名[ASC|DESC];

语法说明:

  • 排序字段名:表示需要排序的字段名称,多个字段时用逗号隔开。
  • ASC|DESCASC表示字段按升序排序;DESC表示字段按降序排序。其中ASC为默认值。

特点

  • ORDER BY子句一般放在查询语句的最后面,LIMIT字句除外。
  • 当排序的字段中存在空值时,ORDER BY会将该空值作为最小值来对待。
  • ORDER BY指定多个字段进行排序时,MySQL会按照字段的顺序从左到右依次进行排序。
  • **注意:**在对多个字段进行排序时,排序的第一个字段必须有相同的值,才会对第二个字段进行排序。如果第一个字段数据中所有的值都是唯一的,MySQL将不再对第二个字段进行排序。

排序查询练习

  1. 根据姓名对员工进行排序(升序)
SELECT* FROM emp ORDER BY ename ASC;
  1. 查询入职时间大于1981年6月6日的员工信息,并按照入职时间升序排列
SELECT* FROM emp WHERE hiredate>'1981-6-6' ORDER BY hiredate DESC;
  1. 根据工作职位,进行升序排列,职位相同的情况下,再根据入职时间降序排列
SELECT* FROM emp ORDER BY job ASC,hiredate DESC;
  1. 查询工资不在1000到2000之间的员工的姓名和工资,工资按降序排列
SELECT * FROM emp WHERE sal<1000 || sal>2000 ORDER BY sal DESC;
  1. 按工作职位进行分组,查看每个工作职位的人数,工作职位按升序排列
SELECT job,COUNT(*) FROM emp GROUP BY job ORDER BY job ASC; 

效果如下:
【③MySQL 数据查询】:提高查询的效率
【③MySQL 数据查询】:提高查询的效率

五、分页查询

对于比较多的数据,如果在一个页面全部显示,查看起来会眼花缭乱。如果能进行分页显示,将更加快捷、清新的浏览!

语法:

SELECT 字段名 FROM 表名 LIMIT 起始索引,查询记录数;

特点:

  • 起始索引从0开始,起始索引=(查询页码-1) 每页显示记录数*
  • 如果查询的是第一页数据,起始索引可以省略,直接简写为LIMIT 10

分页查询练习:

  1. 查询第一页员工数据,每页展示10条记录
SELECT * FROM emp LIMIT 0,10;
  1. 查询工资大于1500的员工数据,按工资升序排列,并分页,每页展示5条数据
SELECT* FROM emp WHERE sal>1500 ORDER BY sal ASC LIMIT 0,5;
SELECT* FROM emp WHERE sal>1500 ORDER BY sal ASC LIMIT 5,5;

效果展示:

【③MySQL 数据查询】:提高查询的效率

六、总结

✨掌握基本的数据查询更有利于我们管理数据,处理数据之间的关系会更加得当~✨下节见✨文章来源地址https://www.toymoban.com/news/detail-499347.html

到了这里,关于【③MySQL 数据查询】:提高查询的效率的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • es 在数据量很大的情况下(数十亿级别)如何提高查询效率?_es能存多少数据

    先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7 深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前! 因此收集整理了一份《2024年最新软件测试全套学习资料》

    2024年04月26日
    浏览(40)
  • 互联网大厂技术-elasticsearch(es)- 在数据量很大的情况下(数十亿级别)提高查询效率

    互联网大厂技术-elasticsearch(es)- 在数据量很大的情况下(数十亿级别)提高查询效率 目录 一、问题分析 二、问题剖析 三、性能优化的杀手锏(filesystem cache) 四、数据预热 五、冷热分离 六、document 模型设计 七、分页性能优化 八、解决方案 这个问题是肯定要问的,说白了,就

    2024年02月04日
    浏览(65)
  • MySQL---表数据高效率查询(简述)

    前言 一、聚合查询 💖聚合函数 💖GROUP BY子句 💖HAVING 二、联合查询 💖内连接 💖外连接 💖自连接 💖子查询 💖合并查询 🎁博主介绍:博客名为tq02,已学C语言、JavaSE,目前学了MySQL和JavaWeb 🎥学习专栏:  C语言         JavaSE       MySQL基础 🎄博主链接:tq02的博客

    2024年02月13日
    浏览(42)
  • MySQL数据库索引优化指南:提升查询效率的利器

    本文将详细探讨MySQL数据库索引的概念、作用以及不同类型的索引,包括主键索引、唯一索引和普通索引。通过实际案例分析,我们将深入理解索引的工作原理,并提供实用的优化建议,帮助读者提升数据库性能。

    2024年02月09日
    浏览(63)
  • MySQL大数据表处理的三种方案,查询效率嘎嘎高

    场景 当我们业务数据库表中的数据越来越多,如果你也和我遇到了以下类似场景,那让我们一起来解决这个问题 数据的插入,查询时长较长 后续业务需求的扩展 在表中新增字段 影响较大 表中的数据并不是所有的都为有效数据 需求只查询时间区间内的 评估表数据体量 我们可

    2024年02月13日
    浏览(36)
  • 查询效率至少提高4倍的MySQL技巧

    SQL语句中IN包含的值不应过多 MySQL对于IN做了相应的优化,即将IN中的常量全部存储在一个数组里面,而且这个数组是排好序的。但是如果数值较多,产生的消耗也是比较大的。再例如:select id from t where num in(1,2,3) 对于连续的数值,能用between就不要用in了;再或者使用连接来替

    2024年04月26日
    浏览(25)
  • openGauss学习笔记-198 openGauss 数据库运维-常见故障定位案例-分析查询效率异常降低的问题

    198.1 分析查询效率异常降低的问题 198.1.1 问题现象 通常在几十毫秒内完成的查询,有时会突然需要几秒的时间完成;而通常需要几秒完成的查询,有时需要半小时才能完成。 198.1.2 处理办法 通过下列的操作步骤,分析查询效率异常降低的原因。 使用analyze命令分析数据库。

    2024年01月16日
    浏览(51)
  • Mysql数据库(五) Mysql命令行客户端:内连接查询、左连接查询、右连接查询、自连接查询、子查询

    目录 一、 连接查询 对多个表进行查询 1.0 数据准备 1.1 连接查询 1.2 内连接 INNER JOIN 1.3 左连接 LEFT JOIN 1.4 右连接 RIGHT JOIN 1.5 FULL OUTER JOIN 1.6 自连接查询 1.7 子查询-嵌套在查询中 在之前的文章当中,我们在 base_1 当中有了一个 stu 表,记录的是学生的name age height等信息 第一步

    2024年02月13日
    浏览(41)
  • MySQL数据库——MySQL WHERE:条件查询数据

    在 MySQL 中,如果需要有条件的从数据表中查询数据,可以使用 WHERE 来指定查询条件。 使用 WHERE 的语法格式如下: WHERE 查询条件 查询条件可以是: 带比较运算符和逻辑运算符的查询条件 带 BETWEEN AND 的查询条件 带 IS NULL 的查询条件 带 IN

    2024年02月03日
    浏览(43)
  • MySQL数据查询

    SELECT SELECT [ALL|DISTINCT] column1,column2,……#ALL表示保留所有,DISTINCT表示去掉目标列值重复的元组 FROM table_name [WHERE condition] [GROUP BY 字段名 HAVING condition]#查询结果按照字段进行分组,该字段相等的为一组 [ORDER BY 字段名 [ASC|DESC]]#每个分组的查询结果按字段排序,ASC升序,DESC降序

    2024年02月15日
    浏览(26)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包