建设银行网站如何修改账单地址小手工在家做

 
文章目录
- 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的值:
 
