MySQL高级查询操作

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


前言

查询语句书写顺序:
1、select
2、from
3、where
4、group by
5、having
6、order by
7、limit

查询语句执行顺序:
数据库的时候先执行from,确定数来自哪张表
再执行where,看看哪些行需要查询
再执行group by,确定是否分组
再执行having,过滤掉不要的组
然后是select,再确定查询哪些列
随后是order by排序
最后是limit限定

MySQL高级查询操作

聚集函数

聚集函数(也叫集合函数),方便用户统计一些数据。
COUNT(*): 统计表中元组个数;
COUNT(列名):统计本列列值个数;
SUM(列名):计算列值总和(必须是数值型列);
AVG(列名):计算列值平均值(必须是数值型列);
MAX(列名):最大、最高;
MIN(列名):最小、最低。

max和min可以统计数字型数据、字符型数据、日期型数据

【例】查询最高最低的学生成绩

SELECT MAX(score),MIN(score)
FROM stu

sum和avg只适用于数字型数据

【例】统计全部学生的平均成绩

SELECT AVG(score) 
FROM stu

count(*)返回表中满足条件的行数
其中*也可以写具体的列名,但是空值不统计

【例】统计老师的总人数

SELECT COUNT(*) 
FROM teacher

查询工作在HK的员工人数,最高工资及最低工资

SELECT count(*) AS 员工人数,max(sal) AS 最高工资,min(sal) AS 最低工资
FROM emp e JOIN dept d 
ON e.deptno = d.deptno 
WHERE loc='HK';

聚合函数不能出现在 WHERE 子句中

分组查询:GROUP BY

当有每个、每组的时候需要分组

SQL语句中使用了分组查询group by,在select子句中就要使用分组统计函数
在select语句中查询分组的列

【例】查每个班级编号,平均成绩,进行分组

SELECT classid,AVG(score)
FROM stu
GROUP BY classid; 

【例】统计每个出版社的出版图书的数目
分析:如果能够将所有的图书,按照出版社的名称进行分组,然后我们在统计每一组的元组的个数,我们就能能到得到期望的数据。

比如book表中字段有:bookid,name,author,public,price

可以使用GROUP BY <列名>进行分组

在<列名>上值相同的元组被分在一组,该列称为分组依据列。
然后可以使用聚集函数统计每一组的数据。

SELECT COUNT(*) , publish FROM book
GROUP BY publish

【例】统计每个人所借图书的数目。

SELECT COUNT(bookid), Reader_id
FROM Borrow 
GROUP BY Reader_id
Having COUNT(bookid)>2

【例】统计每个出版社出版图书的平均价格,并显示每个出版社的名称

SELECT publish, AVG(price) AS 平均价格
FROM book
GROUP BY publish

【例】统计每个岗位和部门都相同的人数

SELECT deptno,job,COUNT(*) AS 人数
FROM emp
GROUP BY deptno,job;

过滤:HAVING

HAVING必须写在GROUP BY后面,ORDER BY前面,HAVING后面也是写条件的(和where相近)

HAVING子句用于过滤掉不满足条件的分组数据,HAVING 子句用于对分组统计后的结果进行筛选。满足HAVING 子句条件将会保留在结果中

WHERE子句中编写的是过滤筛选数据行的条件
HAVING子句是使用分组统计函数的

【例】查询出版图书平均价格高于30元的出版社名称,并显示其图书平均价格。

SELECT publish,AVG(price) FROM book 
GROUP BY publish
HAVING AVG(price)>30

【例】查询出版图书多于2本的出版社名称和出版图书数目

SELECT publish, COUNT(*) FROM book 
GROUP BY publish
HAVING COUNT(*)>2

【例】查询部门编号,岗位,平均工资,其中岗位在销售、经理、职员之中,把岗位和部门都相同的分在一组,保留平均工资高于1000的,平均工资按降序排列

SELECT deptid,job,AVG(sal) AS 平均工资
FROM emp
WHERE job in('salesman','manager','clerk') 
GROUP BY deptid,job
HAVING avg(sal)>1000
ORDER BY 平均工资 DESC; 

【例】查询部门人数大于2的部门编号,部门名称,部门人数。
员工表内字段:deptid
部门表内字段:deptid,dname

SELECT d.deptid,dname,count(*)
FROM emp e JOIN dept d 
ON e.deptid = d.deptid
GROUP BY d.deptno 
HAVING COUNT(*)>2;

【例】查询部门平均工资大于2000,且人数大于2的部门编号,部门名称,部门人数,部门平均工资,并按照部门人数升序排序。
员工表内字段:deptid,sal
部门表内字段:deptid,dname

SELECT d.deptid,dname,COUNT(*),avg(sal)
FROM emp e,dept d
WHERE e.deptid=d.deptid
GROUP BY d.deptid
HAVING avg(sal)>2000
AND COUNT(*)>2
ORDER BY COUNT(*);

嵌套子查询

括号内的查询叫做子查询,也叫内部查询,当条件不知道的时候用子查询

嵌套子查询就是子查询里面有个子查询

NOT IN后面的子查询要确保结果里不能包含空值(IS NOT NULL)

执行顺序:先内层后外层;先查子查询后查主查询

相关子查询运行时和主查询查询的表有关联,使用了主查询表某些列数据

【例】查询成绩最低的学生姓名和学号

解题思路:先写大框,最后写括号里面的东西(查询所有学生里面最低的成绩),变成填空题写

SELECT sname,stuid
FROM stu
WHERE score=(SELECT MIN(score) FROM stu);

【例】查询入学日期比二班入学日期最早的学生还要早的学生姓名,入学日期

SELECT sname,studate
FROM stu
WHERE studate<(SELECT min(studate) FROM stu WHERE classid=2);

比较运算中使用子查询

【例】查询成绩最好的学生的姓名

SELECT name FROM Student 
WHERE Score =(SELECT MAX(Score) FROM Student)

带有IN的子查询

【例】查询与"C语言"在同一出版社的图书信息

SELECT * FROM Book WHERE publish 
IN (SELECT publish FROM Book WHERE name='C语言')

【例】查询张三所借图书的图书编号

SELECT book_ID FROM Borrow 
WHERE reader_ID IN (SELECT reader_ID FROM Reader WHERE name='张三')

【例】查询"张三"所借的图书的名称

SELECT name FROM Book 
WHERE book_ID IN(SELECT book_ID FROM Borrow 
WHERE reader_ID IN (SELECT reader_ID FROM Reader WHERE  name='张三'))

查询过程:
第1步,查询 “张三” 的reader_ID。
第2步,依据 reader_ID在Borrow表中找张三所借图书的book_ID
第3步,依据 book_ID在Book表中找到图书名称。

【例】查询借书价格在20-40之间的读者的姓名

select name from reader 
where reader_id in(select reader_id from borrow 
	where book_id in( select book_id from book 
	where price between 20 and 40))

查询张三 ‘借阅’ 计算机文化基础’的日期

select borrowdate from borrow 
where reader_id in(
	select  reader_id from reader 
	where name='张三')
	and 
	book_id in(
	select book_id from book 
	where name='计算机文化基础')

查询借书价格在20-40之间的读者的姓名

select name from reader where reader_id in(
	select reader_id from borrow 
    where book_id in(
    select book_id from book 
    where price between 20 and 40))

SOME(子查询)

表示子查询的结果集合中某一个元素

【例】查询除不是最低价格外的所有图书

SELECT * FROM Book 
WHERE price>SOME(SELECT price FROM Book)

【例】查询价格最低的图书信息

SELECT * FROM Book 
WHERE NOT(price>SOME(SELECT price FROM Book))

ALL(子查询)

表示子查询的全部结果

【例】查询书价最高的图书的信息

SELECT * FROM Book 
WHERE price >=ALL(SELECT price FROM Book)

【例】查询评价书价最高的出版社名称

SELECT * FROM Book 
GROUP BY public
HAVING AVG(price)>=ALL(
	SELECT AVG(price) FROM Book
	GROUP BY public)

EXISTS子查询

判断子查询是否存在结果

当子查询存在结果时,EXISTS(子查询)返回值为true,否则返回值为false。

先外层查询,后内层查询;
将外层的值代入内层进行查询,根据内层查询是否存在结果,判断外层的元组是否保留在结果集中。

【例】查询借阅了图书的读者的姓名

SELECT name FROM reader WHERE 
EXISTS ( SELECT * FROM borrow WHERE     
borrow.reader_id=reader.reader_id)

【例】查询被借出的图书的信息文章来源地址https://www.toymoban.com/news/detail-465056.html

SELECT * FROM Book 
WHERE EXISTS(SELECT * FROM Borrow WHERE Borrow.book_ID=Book.book_ID)

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

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

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

相关文章

  • 数据库应用:MySQL数据库SQL高级语句与操作

    目录 一、理论 1.克隆表与清空表 2.SQL高级语句 3.SQL函数 4.SQL高级操作 5.MySQL中6种常见的约束 二、实验  1.克隆表与清空表 2.SQL高级语句 3.SQL函数 4.SQL高级操作 5.主键表和外键表  三、总结 克隆表:将数据表的数据记录生成到新的表中。 (1)克隆表 ① 先创建再导入 ② 创建

    2024年02月13日
    浏览(60)
  • C#操作MySQL从入门到精通(8)——对查询数据进行高级过滤

    我们在查询数据库中数据的时候,有时候需要剔除一些我们不想要的数据,这时候就需要对数据进行过滤,比如学生信息中,我只需要年龄等于18的,同时又要家乡地址是安徽的,类似这种操作专栏第7篇的C#操作MySQL从入门到精通(7)——对查询数据进行简单过滤简单过滤方法就

    2024年04月15日
    浏览(38)
  • 数据库 SQL高级查询语句:聚合查询,多表查询,连接查询

    创建Students和Courses表 直接查询 设置别名查询 设置条件查询 使用COUNT(*) 和 COUNT(StudentID)是一样的效果,因为StudentID是主键,每行记录的主键都不同。另外我们在聚合查询中还是能使用WHERE子句的,比如我们要 查找年龄大于20岁的学生数量 ,可使用以下SQL语句: 函数 说明 SUM

    2024年02月09日
    浏览(99)
  • MySQL高级语句(一)

    显示表格中一个或数个栏位的所有资料 语法:SELECT \\\"字段\\\" FROM \\\"表名\\\"; 不显示重复的内容 语法:SELECT DISTINCT \\\"字段\\\" FROM \\\"表名\\\"; 条件查询 语法:SELECT \\\"字段\\\" FROM \\\"表名\\\" WHERE \\\"条件\\\"; 代表且、或、和的意思 语法:SELECT \\\"字段\\\" FROM \\\"表名\\\" WHERE \\\"条件1\\\" {[AND|OR] \\\"条件2\\\"}; 显示已知的值的

    2024年02月05日
    浏览(32)
  • MYSQL高级语句

    create table location (Region char(20),Store_Name char(20)); insert into location values(\\\'East\\\',\\\'Boston\\\'); insert into location values(\\\'East\\\',\\\'New York\\\'); insert into location values(\\\'West\\\',\\\'Los Angeles\\\'); insert into location values(\\\'West\\\',\\\'Houston\\\'); location 表格 +----------+--------------+ | Region   | Store_Name   | |----------+--------------| | Eas

    2024年02月03日
    浏览(22)
  • MySQL高级(进阶)SQL语句

    #显示一个字段或者多个字段的所有内容 SELECT “字段” FROM 表名 ; #distinct对字段去重查询 (最好只对单个字段进行去重) SELECT DISTINCT 字段名 FROM 表名 #where 有条件查询 SELECT “字段” FROM 表名 WHERE 条件(例如:sales =!= 100); #and or 查看多个条件 SELECT “字段” FROM 表名 WHE

    2024年02月05日
    浏览(28)
  • mysql高级sql语句-全面

    显示表格中一个或数个字段的所有数据记录 在已知的字段数据取值范围内取值 在两个字段数据值之间取值,包含两边字段的数据 通常通配符都是与like配合使用的 % :百分号表示零个、一个或多个字符 _ :下划线表示单个字符 名称 作用 举例 ‘A_Z’ 所有以 ‘A’ 起头,另一

    2024年02月11日
    浏览(27)
  • MySQL 高级(进阶) SQL 语句

     创建两表以供使用   ---- SELECT ----显示表格中一个或数个字段的所有数据记录 ---- DISTINCT ----不显示重复的数据记录 ---- WHERE ----有条件查询 ---- AND OR ----且 或 ---- IN ----显示已知的值的数据记录 ---- BETWEEN ----显示两个值范围内的数据记录(包含边界值) ---- 通配符 ----通常通配

    2024年02月10日
    浏览(33)
  • MySQL 高级(进阶) SQL 语句二

    MYSQL数据库中的三种连接: inner join(内连接):只返回两个表中联结字段相等的行(有交集的值) left join(左连接):返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右连接):返回包括右表中的所有记录和左表中联结字段相等的记录 注:oracle数据库支持 outer

    2024年02月07日
    浏览(32)
  • MySQL数据库管理高级语句

    复制表及内容     克隆表 获取数据表的表结构、索引等信息    清空表,删除表内的所有数据       删除的特点: 创建临时表 临时表创建成功之后,使用SHOWTABLES命令是看不到创建的临时表的, 临时表会在连接退出后被销毁。 如果在退出连接之前,也可以可执行增删改查

    2024年02月11日
    浏览(47)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包