MySQL的内置函数

MySQL的内置函数_第1张图片

文章目录

  • 1. 聚合函数
  • 2. group by子句的使用
  • 3. 日期函数
  • 4. 字符串函
  • 5. 数学函数
  • 6. 其它函数

1. 聚合函数

COUNT([DISTINCT] expr) 返回查询到的数据的数量
MySQL的内置函数_第2张图片
用SELECT COUNT(*) FROM students或者SELECT COUNT(1) FROM students也能查询总个数。

统计本次考试的数学成绩分数去重个数:
MySQL的内置函数_第3张图片
SUM([DISTINCT] expr) 返回查询到的数据的 总和,不是数字没有意义
MySQL的内置函数_第4张图片
AVG([DISTINCT] expr) 返回查询到的数据的 平均值,不是数字没有意义
求每个同学的平均分排名:
MySQL的内置函数_第5张图片
MAX([DISTINCT] expr) 返回查询到的数据的 最大值,不是数字没有意义
返回英语最高分:
MySQL的内置函数_第6张图片
MIN([DISTINCT] expr) 返回查询到的数据的 最小值,不是数字没有意义
返回 > 70 分以上的数学最低分:
MySQL的内置函数_第7张图片
聚合统计一定是直接或者间接统计列方向的某些数据,它们的属性一定相同

2. group by子句的使用

在select中使用group by 子句可以对指定列进行分组查询:
在这里插入图片描述
举个例子:
MySQL的内置函数_第8张图片
MySQL的内置函数_第9张图片
下面我们把这个数据库备份放到我们的数据库中:
MySQL的内置函数_第10张图片
这里我们成功获取这3张表。

MySQL的内置函数_第11张图片
这是部门表,第一个字段是部门编号,第二个字段是部门名称,第三个字段是部门所在地点。
MySQL的内置函数_第12张图片
这是员工表,字段的意思依次是:雇员编号、雇员姓名、雇员职位、雇员领导编号、雇佣时间、工资月薪、奖金、部门编号。
MySQL的内置函数_第13张图片
这是工资等级表,字段的意思依次是:等级、此等级最低工资、此等级最高工资。
MySQL的内置函数_第14张图片
MySQL的内置函数_第15张图片
MySQL的内置函数_第16张图片
我们已经在这3张表中插入了数据。

如何显示每个部门的平均工资和最高工资?
MySQL的内置函数_第17张图片
因为4号部门没有员工,所以就不显示。

如何显示每个部门的每种岗位的平均工资和最低工资?
MySQL的内置函数_第18张图片
如何显示平均工资低于2000的部门和它的平均工资?

这里我们不能使用where来筛选了,需要使用having:
MySQL的内置函数_第19张图片
总结:
1.group by是通过分组这样的手段,为未来进行聚合统计提供基本信息的功能支持(group by一定是通过聚合统计来使用的)

2.group by后面跟的都是分组的字段依据,只有在group by后面出现的字段,未来在聚合统计的时候,才能在select后面出现

3.where和having它们两个是不冲突的,是互相补充的,having通常是在完成整个分组统计后,再进行筛选。where是在表中数据初步筛选的时候起作用的

SQL查询中各个关键字的执行先后顺序 from > on> join > where > group by > with > having > select> distinct > order by > limit

3. 日期函数

MySQL的内置函数_第20张图片
获得时间戳:
MySQL的内置函数_第21张图片
它的作用和now()一样。

在日期的基础上加天数:
MySQL的内置函数_第22张图片
我们也可以加上年,分钟,秒。

计算两个日期之间相差多少天:
MySQL的内置函数_第23张图片

创建一个留言表:
MySQL的内置函数_第24张图片
插入数据:
MySQL的内置函数_第25张图片
显示所有留言信息,发布日期只显示日期,不用显示时间:
MySQL的内置函数_第26张图片
data函数会把我们的时间只保留日期格式。

请查询在2分钟内发布的帖子
如果我们现在的时间减去2分钟的时间,在这个时间端就是2分钟内发布的帖子,换算一下就是发布的帖子+2分钟大于现在的时间。

select * from msg where date_add(sendtime, interval 2 minute) > now();

4. 字符串函

MySQL的内置函数_第27张图片
获取emp表的ename列的字符集:
MySQL的内置函数_第28张图片
要求显示员工表中的信息,显示格式:“XXX的工作是XXX,薪水是XXX”:
MySQL的内置函数_第29张图片
求员工表中员工姓名占用的字节数:
MySQL的内置函数_第30张图片
注意:length函数返回字符串长度,以字节为单位。如果是多字节字符则计算多个字节数,如果是单字节字符则算作一个字节。比如:字母,数字算作一个字节,中文表示多个字节数(与字符集编码有关)。
MySQL的内置函数_第31张图片
substring函数的作用是:取某个字符串的一部分,并且可以指定要取长度的大小,从1开始。
MySQL的内置函数_第32张图片
replace可以进行字符串的替换。

以首字母小写的方式显示所有员工的姓名:
MySQL的内置函数_第33张图片
查出所有员工的工作是CLERK的:
MySQL的内置函数_第34张图片
如果我们想查询的不是的话,我们就什么都不带。
MySQL的内置函数_第35张图片

5. 数学函数

MySQL的内置函数_第36张图片
保留2位小数位数(小数四舍五入):
MySQL的内置函数_第37张图片
将10从10进制转成16进制:
MySQL的内置函数_第38张图片

6. 其它函数

user() 查询当前用户:
MySQL的内置函数_第39张图片
md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串:
MySQL的内置函数_第40张图片
password()函数,MySQL数据库使用该函数对用户加密:
MySQL的内置函数_第41张图片
下面我们创建一个用户表,密码是加密的:
MySQL的内置函数_第42张图片
下面我们进行插入:
MySQL的内置函数_第43张图片
并且加密的,不会显示在MySQL中的历史语句中。

如果用户输入密码,怎么比较呢
MySQL的内置函数_第44张图片
ifnull(val1, val2) 如果val1为null,返回val2,否则返回val1的值:
MySQL的内置函数_第45张图片

你可能感兴趣的:(MySql,mysql,数据库)