函数 是指一段可以直接被另一段程序调用的程序或代码。 也就意味着,这一段程序或代码在MySQL中已经给我们提供了,我们要做的就是在合适的业务场景调用对应的函数完成对应的业务需求即可。 那么,函数到底在哪儿使用呢?
我们先来看两个场景:
1). 在企业的OA或其他的人力系统中,经常会提供的有这样一个功能,每一个员工登录上来之后都能够看到当前员工入职的天数。而在数据库中,存储的都是入职日期,如2000-11-12,那如果快速计算出天数呢?
2). 在做报表这类的业务需求中,我们要展示出学员的分数等级分布。而在数据库中,存储的是学生的分数值,如98/75,如何快速判定分数的等级呢?其实,上述的这一类的需求呢,我们通过MySQL中的函数都可以很方便的实现。
MySQL中的函数主要分为以下四类:字符串函数、数值函数、日期函数、流程函数。
MySQL中内置了很多字符串函数,常用的几个如下:
演示如下:
A. concat : 字符串拼接
C. upper : 全部转大写D. lpad : 左填充select lpad('01', 5, '-');
E. rpad : 右填充
G. substring : 截取子字符串案例:由于业务需求变更,企业员工的工号,统一为5位数,目前不足5位数的全部在前面补0。比如: 1号员工的工号应该为00001。update emp set workno = lpad(workno, 5, '0');
处理完毕后, 具体的数据为:
常见的数值函数如下:
演示如下:
A. ceil:向上取整
C. mod:取模D. rand:获取随机数select rand();
E. round:四舍五入
常见的日期函数如下:演示如下:A. curdate:当前日期B. curtime:当前时间select curtime();
C. now:当前日期和时间
E. date_add:增加指定的时间间隔F. datediff:获取两个日期相差的天数select datediff('2021-10-01', '2021-12-01');
案例:
查询所有员工的入职天数,并根据入职天数倒序排序。入职天数,就是通过当前日期 - 入职日期,所以需要使用datediff函数来完成。
B. ifnullC. case when then else end需求: 查询emp表的员工姓名和工作地址 (北京/上海 ----> 一线城市 , 其他 ----> 二线城市)select name, ( case workaddress when '北京' then '一线城市' when '上海' then '一线城市' else '二线城市' end ) as '工作地址' from emp;
案例:
具体的SQL语句如下:select id, name, (case when math >= 85 then '优秀' when math >=60 then '及格' else '不及格' end ) '数学', (case when english >= 85 then '优秀' when english >=60 then '及格' else '不及格' end ) '英语', (case when chinese >= 85 then '优秀' when chinese >=60 then '及格' else '不及格' end ) '语文' from score;
MySQL的常见函数我们学习完了,那接下来,我们就来分析一下,在前面讲到的两个函数的案例场景,思考一下需要用到什么样的函数来实现?
1). 数据库中,存储的是入职日期,如 2000-01-01,如何快速计算出入职天数呢? -------->
答案: datediff
2). 数据库中,存储的是学生的分数值,如98、75,如何快速判定分数的等级呢? ---------->
答案: case ... when ...