开网站设计公司多少钱中国十大装修公司排名

文章目录
- 1. 聚合函数
- 2. group by子句的使用
- 3. 日期函数
- 4. 字符串函
- 5. 数学函数
- 6. 其它函数
1. 聚合函数
COUNT([DISTINCT] expr) 返回查询到的数据的数量

用SELECT COUNT(*) FROM students或者SELECT COUNT(1) FROM students也能查询总个数。
统计本次考试的数学成绩分数去重个数:

SUM([DISTINCT] expr) 返回查询到的数据的 总和,不是数字没有意义

AVG([DISTINCT] expr) 返回查询到的数据的 平均值,不是数字没有意义
求每个同学的平均分排名:

MAX([DISTINCT] expr) 返回查询到的数据的 最大值,不是数字没有意义
返回英语最高分:

MIN([DISTINCT] expr) 返回查询到的数据的 最小值,不是数字没有意义
返回 > 70 分以上的数学最低分:

聚合统计一定是直接或者间接统计列方向的某些数据,它们的属性一定相同。
2. group by子句的使用
在select中使用group by 子句可以对指定列进行分组查询:

举个例子:


下面我们把这个数据库备份放到我们的数据库中:

这里我们成功获取这3张表。

这是部门表,第一个字段是部门编号,第二个字段是部门名称,第三个字段是部门所在地点。

这是员工表,字段的意思依次是:雇员编号、雇员姓名、雇员职位、雇员领导编号、雇佣时间、工资月薪、奖金、部门编号。

这是工资等级表,字段的意思依次是:等级、此等级最低工资、此等级最高工资。



我们已经在这3张表中插入了数据。
如何显示每个部门的平均工资和最高工资?

因为4号部门没有员工,所以就不显示。
如何显示每个部门的每种岗位的平均工资和最低工资?

如何显示平均工资低于2000的部门和它的平均工资?
这里我们不能使用where来筛选了,需要使用having:

总结:
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. 日期函数

获得时间戳:

它的作用和now()一样。
在日期的基础上加天数:

我们也可以加上年,分钟,秒。
计算两个日期之间相差多少天:

创建一个留言表:

插入数据:

显示所有留言信息,发布日期只显示日期,不用显示时间:

data函数会把我们的时间只保留日期格式。
请查询在2分钟内发布的帖子:
如果我们现在的时间减去2分钟的时间,在这个时间端就是2分钟内发布的帖子,换算一下就是发布的帖子+2分钟大于现在的时间。
select * from msg where date_add(sendtime, interval 2 minute) > now();
4. 字符串函

获取emp表的ename列的字符集:

要求显示员工表中的信息,显示格式:“XXX的工作是XXX,薪水是XXX”:

求员工表中员工姓名占用的字节数:

注意:length函数返回字符串长度,以字节为单位。如果是多字节字符则计算多个字节数,如果是单字节字符则算作一个字节。比如:字母,数字算作一个字节,中文表示多个字节数(与字符集编码有关)。

substring函数的作用是:取某个字符串的一部分,并且可以指定要取长度的大小,从1开始。

replace可以进行字符串的替换。
以首字母小写的方式显示所有员工的姓名:

查出所有员工的工作是CLERK的:

如果我们想查询的不是的话,我们就什么都不带。

5. 数学函数

保留2位小数位数(小数四舍五入):

将10从10进制转成16进制:

6. 其它函数
user() 查询当前用户:

md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串:

password()函数,MySQL数据库使用该函数对用户加密:

下面我们创建一个用户表,密码是加密的:

下面我们进行插入:

并且加密的,不会显示在MySQL中的历史语句中。
如果用户输入密码,怎么比较呢?

ifnull(val1, val2) 如果val1为null,返回val2,否则返回val1的值:

