美文网首页
MySQL数据库开发技术——高级查询

MySQL数据库开发技术——高级查询

作者: 狼人_4e19 | 来源:发表于2018-11-17 09:43 被阅读0次

    分组函数是对数据行的集合进行操作并按组给出一个结果,这个结果可直接输出,或者用来做判断条件。

    单行函数和分组函数区别

    1.单行输入单行输出;
    2.一组或多组输入输出只有一个结果;

    分组函数常用到一下五个函数:

    • MIN
    • MAX
    MIN和MAX函数主要是返回每组的最小值和最大值。
    MIN和MAX可以用于任何数据类型
    – 查询入职日期最早和最晚的、


    图片.png

    • SUM
    • AVG
    – SUM和AVG函数分别返回每组的总和及平均值。
    SUM和AVG函数都是只能够对数值类型的列或表达式操作。
    – 查询职位以SALES开头的所有员工平均工资、最低工资、最高工资、
    工资和。


    图片.png

    • COUNT
    COUNT函数的主要功能是返回满足条件的每组记录条数。
    查询部门30有多少个员工


    图片.png
    组函数中distinct

    DISTINCT会消除重复记录后再使用组函数


    图片.png
    分组函数中空值处理
    图片.png
    在分组函数中使用ifnull

    -ifnull 函数可以使函数强制包含含有空值的记录


    图片.png

    创建数据组

    用group by子句创建数据组

    通过 GROUP BY 子句可将表中满足WHERE条件的记录按照
    指定的列划分成若干个小组
    – 其中GROUP BY子句指定要分组的列
    -GROUP BY 所指定的列并不是必须出现在SELECT 列表中。


    图片.png

    排除组结果

    不能在where语句中限制组
    可以通过having子句限制组
    • 使用 HAVING 子句限制组
    – 记录已经分组.
    – 使用过组函数.
    – 与 HAVING 子句匹配的结果才输出
    having放group by order by后固定语法


    图片.png

    • SELECT语句执行过程:
    – 1.通过FROM子句中找到需要查询的表;
    – 2.通过WHERE子句进行非分组函数筛选判断;
    – 3.通过GROUP BY子句完成分组操作;
    – 4.通过HAVING子句完成组函数筛选判断;
    – 5.通过SELECT子句选择显示的列或表达式及组函数;
    – 6.通过ORDER BY子句进行排序操作。

    子查询概述

    图片.png

    -括号内的查询叫子查询,先于主查询执行。
    • 子查询的结果被主查询(外部查询)使用
    • expr operator包括比较运算符。
    – 单行运算符:>、=、>=、<、<>、<=
    – 多行运算符: IN、ANY、ALL
    -子查询可以嵌入以下SQL子句中:
    -where子句
    -having子句
    -from子句

    in的使用
    any的使用

    any:表示和子查询的任意一行结果进行比较,有一个满足条件即可。
    • < ANY:表示小于子查询结果集中的任意一个,即小于最
    大值就可以。
    • > ANY:表示大于子查询结果集中的任意一个,即大于最
    小值就可以。
    • = ANY:表示等于子查询结果中的任意一个,即等于谁都
    可以,相当于IN。


    图片.png

    all的使用

    all :表示和子查询的所有行结果进行比较,每一行都必须满足条件。
    • < ALL:表示小于子查询结果集中的所有行,即小于最小
    值。
    • > ALL:表示大于子查询结果集中的所有行,即大于最大
    值。
    • = ALL :表示等于子查询结果集中的所有行,即等于所有
    值,通常无意义。


    图片.png

    子查询中的空值

    图片.png

    子查询返回的结果中含有空值
    上面的SQL语句试图查找出没有下属的雇员,逻辑上,这个SQL语句应该
    会返回8条记录,但是却一条也没返回,why?
    因为子查询的结果中有一条空值,这条空值导致主查询没有记录返回。
    这是因为所有的条件和空值比较结果都是空值。因此无论什么时候只要
    空值有可能成为子查询结果集合中的一部分,就不能使用NOT IN 运算符

    在from子句中使用子查询

    图片.png

    相关文章

      网友评论

          本文标题:MySQL数据库开发技术——高级查询

          本文链接:https://www.haomeiwen.com/subject/jvapfqtx.html