共计 2610 个字符,预计需要花费 7 分钟才能阅读完成。
自动写代码机器人,免费开通
这篇文章主要介绍 MySQL 查询语句之复杂查询的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
MySQL 是一种关系数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。在 MySQL 中经常会有很多复杂的查询,比如:
MySQL 复杂查询
一、分组查询:
1、关键字:GROUP
BY
2、用法:GROUP
BY 语句用于结合合计函数 (比如 SUM),根据一个或多个列对结果集进行分组, 合计函数常常需要添加
GROUP BY 语句。
下面的给了两张表 一张是 emp, 一张是 dept, 下面的查询我们都对这两张表进行操作,如下图:
第一张:emp 表
第二张:dept 表
现在我们查询 emp 每个部门的工资总和, 语句如下:
SELECT deptno,SUM(sal)FROM emp GROUP BY deptno;
结果如下:
注:这里我们查询每个部门的工资 (sal) 总和,所以应该按照部门标号 (deptno) 进行分组,求和所以用了 sum();
3、having:
where 和 having 都是做条件判断,在介绍 having 前我们看下 where 和 having 的区别
where 的作用是在对查询结果进行分组前,将不符合 where 条件的行去掉,即在分组之前过滤数据,条件中不能包含聚合函数,使用 where 条件显示特定的行。
having 的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚合函数,使用 having条件显示特定的组,也可以使用多个分组标准进行分组。
例如: 我们要查询 emp 表中工资总和大于 10000 的部门编号, 语句如下:
SELECT
deptno,SUM(sal)FROM emp GROUP BY deptno HAVING SUM(sal) 10000;
结果如下:
这样就查出了工资总和大于 10000 的部门编号为 20,(为了理解也把工资总和显示出来了)。
二、连表查询:
根据两个或多个表中的列之间的关系,从这些表中查询数据.
1、inner join(内连接):
语法:select 字段名 1,字段名 2 from table1 [INNER] join table2 ON table1. 字段名 =table2. 字段名;
注: 内连接是从结果中删除其他被连接的表中没有匹配行的所有行,只能查询出连接的表中都拥有的信息,所以内连接可能会丢失信息,还有 inner 可以省略。
例如: 我们连接 emp 和 dept 两张表, 查询 ename 和 deptno, 语句如下:
SELECT emp.ename,dept.deptno FROM emp INNER JOIN dept ON emp.deptno=dept.deptno;
还有种写法:SELECT emp.ename,dept.deptno from emp,dept where emp.deptno=dept.deptno;
注意: 原来 dept 表中有 deptno 为 40 的, 但查询出来就没有了,这里是因为 emp 中 deptno 字段中没有值为 40,所以使用 innner join 连接时就自动删除了 dept 表中 deptno 字段值为 40 的记录。
2、外连接:
2.1: 左外连接: 结果集保留左表的所有行,但只包含第二个表与第一表匹配的行。第二个表相应的空行被放入 NULL 值。
2.2: 右外连接: 结果集保留右表的所有行,但只包含第二个表与第一表匹配的行。第二个表相应的空行被放入 NULL 值。
左外连接和右外连接交换两个表的位置就可以达到相同的效果。
现在我们进行分组和连表一起用的查询
例如: 我们要查询 emp 每个部门的工资总和并且对应 dept 表中的部门名称
解析这句话: 查询的字段是 emp 中的每个部门 sal(工资总和),这里就要用到分组查询, 但是还要查询到对应部门的部门名称(dname),由于 dname
是在 dept 表中,所以就应该连接 emp 和 dept 两张表.
思路 1: 我们先查询出我们需要的所有字段再进行分组, 所以先连接再分组, 语句如下:
SELECT e.deptno,d.dname,SUM(e.sal) FROM emp e INNER JOIN dept d ON e.deptno=d.deptno GROUP BY d.deptno;)(注意这里使
用了别名 emp 的别名是 e,dept 的别名是 d)
第二种写法:
SELECT e.deptno,d.dname,SUM(e.sal) FROM emp e,dept d WHEREe.deptno=d.deptno GROUP BY d.deptno;
这两种写法的结果都是一样,如下:
思路 2:我们要查询 emp 每个部门的工资总和,把这个结果集当作一个表(这里称为表 1),再让表 1 去连接 dept 表查询出对应的部门名称(dname);
分步 1:SELECT deptno,SUM(sal) FROM emp GROUP BY deptno; 这个语句就查询出了 emp 表中每个部门的工资总和,现在我们再与 dept
表连接:
分步 2:SELECT xin.*,d.dname FROM(SELECT deptno,SUM(sal) FROM emp GROUP BY deptno) xin INNER JOIN dept d ON xin.deptno
=d.deptno; 这样就查询出了想要的结果, 注意这里的 xin 是别名,结果如下:
这里的代码看起来很长,其实思路是很明确的,就是把第一个查询结果当作一张表去连接另一张表,这样的思路不容易出错,多练习写起来就
很熟练了。
三、分页:
关键字:LIMIT
语法:select * from tableName 条件 limit 当前页码 * 页面容量 -1 , 页面容量;
一般 limit 都和 order by 连用
例如 我们要查询 emp 表中按部门编号升序排列的 5 -10 的记录,每页显示 5 条记录, 语句如下:
SELECT *FROM emp ORDER BY deptno LIMIT 4,5;
这样就可以查询出想要的结果了,注意最后一个参数 5 是页面容量,也就是本页要显示的行数(即本页开始行到结束行的记录条数)。
比如我们要查询 17 页的记录,每页显示 10 条记录:
LIMIT 17*10-1,10;
四:IN
关键字:In
子查询的返回值结果不只一个条件就必须用 IN 不能用 =
注:LIMIT 都是放在最后的。
以上是“MySQL 查询语句之复杂查询的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注丸趣 TV 行业资讯频道!
向 AI 问一下细节