MySQL学习笔记之:数据排序 / 常用的单行函数 / 常用的分组函数 / 分组查询

数据排序:

  • 语法:
    在这里插入图片描述

  • 特点:
    ASC 代表升序,DESC 代表降序,如果不写默认是升序

  • 案例:
    在这里插入图片描述在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    注意:这里的两次排序代表的是先执行第一次排序,如果出现工资相同的情况就按第二个标准进行排序。

  • 总结:

    • ASC 代表升序,DESC 代表降序,如果不写默认是升序
    • order by 子句可以支持单个字段,多个字段,表达式,函数,别名
    • order by 子句一般是放在查询语句的最后面使用,但是limit 子句除外,如果出现了limit 要放在order by后面,其他的都放前面。
    • 执行顺序:在这里插入图片描述

1. 单行函数

1. 字符函数

  • length:用来获取参数值的字节个数
    • length 函数是按照字节进行统计的
    • 汉字在 utf8 中占三个字节

  • concat:拼接字符串
    在这里插入图片描述

  • substr:子字符串
    在这里插入图片描述
    注意: 这个函数进行了 4 次重载,可以有四种使用的方法
    ① 只给一个参数的时候,表示的是从这个参数后面所有的字符在这里插入图片描述
    ② 给两个参数的时候,第一个参数代表开始的位置,第二个参数代表的是截取的长度在这里插入图片描述
    综合案例:
    在这里插入图片描述

  • instr:字符串第一次出现的位置,没出现则返回 0
    在这里插入图片描述

  • trim:去掉前、后的空格和固定字符串
    在这里插入图片描述
    当然,也可以用这种方式来去掉前后的固定字符串,不过要添加一个 ’ ’ from …
    在这里插入图片描述
    但是可以看到,中间的字符串被认为是原字符串的一部分,所以不能去掉

  • upper,lower:改变大小写
    在这里插入图片描述

  • lpad:用指定的字符,以左填充的方式补全字符串到特定的长度
    在这里插入图片描述
    注意:当指定字符串的长度小于原字符串自身长度的时候,就截取到指定长度
    在这里插入图片描述

  • rpad:用指定的字符,以右填充的方式补全字符串到特定的长度
    在这里插入图片描述

  • replace:替换指定的字符串
    在这里插入图片描述
    注意:replace 将所有的项目全部替换

2. 数学函数

  • round:四舍五入
    在这里插入图片描述
    只给一个参数的时候,进行四舍五入的运算
    给两个参数的时候,是精确到小数点后多少位

  • ceil:向上取整数,返回 >= 该参数的最小整数在这里插入图片描述

  • floor:向下取整数,返回 <= 该参数的最小整数
    在这里插入图片描述

  • truncate:截断函数,直接取小数点后面多少位
    在这里插入图片描述

  • mod:取余,相当于 %
    在这里插入图片描述
    MOD(a,b) 相当于进行如下的运算: a - a / b * b

3. 日期函数

  • now:返回当前系统的日期+时间
    在这里插入图片描述
  • curdate:返回当前系统日期,不包含时间
    在这里插入图片描述
  • curtime:返回当前的时间,不包含日期
    在这里插入图片描述

下面的函数,用来获取指定的部分:年、月、日、小时、分钟、秒。

  • year
    在这里插入图片描述
    在这里插入图片描述
  • month
    ① 显示月份的数值
    在这里插入图片描述
    ② 显示月份的英文名称
    在这里插入图片描述
  • monthname
  • day
  • hour
  • minute
  • second

  • str_to_date:将日期格式的字符转换成指定格式的日期
    在这里插入图片描述
    意思是,拿到一个形式不规范的日期,使用 str_to_date 函数,可以通过设置他的 m,d,Y 来把它变成右边的规范形式

  • date_format:将日期转换成字符
    在这里插入图片描述

上面出现的 m,d,Y 均出自下面表格
在这里插入图片描述

【补充】:datediff 函数,可以算两个日期之间的差值

在这里插入图片描述

4. 其他函数

  • version:查看当前的版本号
    在这里插入图片描述
  • database:查看当前的数据库
    在这里插入图片描述
  • user:代表当前的用户
    在这里插入图片描述

5. 流程控制函数

  • if:如果为真,返回第一个参数,如果是假,返回第二个参数;类似于三目运算符
    在这里插入图片描述
    在这里插入图片描述

  • case:
    ① 类似于 switch case 的效果
    在这里插入图片描述
    在这里插入图片描述
    类似于多重 if 语句
    在这里插入图片描述
    在这里插入图片描述
    **总结来说:**第 ① 种情况通常用于固定值的匹配,比如说部门的 id 一共只有几类,但是第 ② 中情况通常用于一个范围的匹配,例如图中的工资范围。

2. 分组函数

功能:主要用作统计使用,又称为“聚合函数”或者“统计函数”或者组函数。

  • sum:求和
  • avg:取平均值
  • max:取最大值
  • min:取最小值
  • count:计算个数

在这里插入图片描述

特点1:
在这里插入图片描述

  • sum, avg 一般用于处理数值型
  • max, min, count 可以处理任何类型

特点2:

  • sum 、 avg、max、min、count 在运算的时候,遇到 null 值,自动忽略。

特点3:

  • 可以和 distinct 搭配来去重
    在这里插入图片描述
    在进行 sum 运算之间,先将重复的部分去除,然后在进行运算。
    在这里插入图片描述

特点4:count 函数的详细介绍

在这里插入图片描述

  • count 函数支持 4 种重载;
  • 以下方式都可以得到 表的行数
    在这里插入图片描述
  • 执行效率:
    ① MYISAM 存储引擎下,count(*) 的效率最高;因为这个引擎的内部有一个计数器,直接返回计数器的个数,所以是最高的
    ② INNODB 存储引擎下,count(*)count(1) 的效率差不多,比 count(字段)的效率高。

特点5:和分组函数一同查询的字段有限制
在这里插入图片描述
如果不进行匹配的话,虽然不会报错,但是结果是错误的。

  • 和分组函数一同查询的字段要求是 group by 后的 字段。

3. 分组查询

在这里插入图片描述

  • group by 要放在 where 子句的后面
  • order by 放在最后

3.1 简单的分组查询

在这里插入图片描述
在这里插入图片描述

3.2 添加筛选条件的分组查询

在这里插入图片描述
在这里插入图片描述

3.3 添加复杂筛选条件的分组查询

在这里插入图片描述

  • 对待如上的复杂查询,要先根据第 ① 步把每个部门的员工个数都得出来,并且得到一个新的表,然后以此为基础实现第 ② 步,筛选出部门员工数 > 2的情况。

在这里插入图片描述

  • 第 ① 步要按照分组的做法分出来每个工种有奖金的员工的最高工资,并且形成新的表
  • 第 ② 步完成最高工资 > 12000 的筛选

在这里插入图片描述
自己理解: 因为以 manage_id 进行分类,但是 manage_id 里面本来没有最低工资这个条件,所以这个条件应该属于条件外的, 应该用 where 语句,而 manage_id > 102 是 manage_id 内部的条件, 应该用 where 语句来进行分类~。

3.4 按照函数分组的分组查询

在这里插入图片描述

3.5 按多个字段进行分组

在这里插入图片描述

3.6 分组查询之后添加排序

在这里插入图片描述

  • 根据前面说的,只需要在后面加一个 order by 即可。

总结分组查询的所有知识点
在这里插入图片描述

  • 分组前筛选代表的是 where 筛选方式
  • 分组后筛选代表的是 having 的筛选方式
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

暖仔会飞

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值