MySQL内置函数
- 日期函数
- 字符串函数
- 数学函数
- 其他函数
-
- [user() 查询当前用户](#user() 查询当前用户)
- md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串
- database()显示当前正在使用的数据库
- password()函数,MySQL数据库使用该函数对用户加密
- [ifnull(val1, val2) 如果val1为null,返回val2,否则返回val1的值](#ifnull(val1, val2) 如果val1为null,返回val2,否则返回val1的值)
- 练习题
日期函数

- 获得年月日

- 获得时分秒:

- 获得时间戳

- 在日期的基础上加日期:

- 在日期的基础上减去时间:

- 计算两个日期之间相差多少天:

字符串函数


- 获取emp表的ename列的字符集
sql
select charset(ename) from EMP;
- 要求显示exam_result表中的信息,显示格式:"XXX的语文是XXX分,数学XXX分,英语XXX分"
sql
select concat(name, '的语文是',chinese,'分,数学是',math,'分') as '分数' from
student;
- 求学生表中学生姓名占用的字节数
sql
select length(name), name from student;
注意:length函数返回字符串长度,以字节为单位。如果是多字节字符则计算多个字节数;
如果是单字节字符则算作一个字节。比如:字母,数字算作一个字节,中文表示多个字节数(与字符集编码有关)
- 将EMP表中所有名字中有S的替换成'上海'
sql
select replace(ename, 'S', '上海') ,ename from EMP;
- 截取EMP表中ename字段的第二个到第三个字符
sql
select substring(ename, 2, 2), ename from EMP;
- 以首字母小写的方式显示所有员工的姓名
sql
select concat(lcase(substring(ename, 1, 1)),substring(ename,2)) from EMP;
数学函数

- 绝对值
sql
select abs(-100.2);
- 向上取整
sql
select ceiling(23.04);
- 向下取整
sql
select floor(23.7);
- 保留2位小数位数(小数四舍五入)
sql
select format(12.3456, 2);
- 产生随机数
sql
select rand();
其他函数
user() 查询当前用户
sql
select user();
md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串
sql

database()显示当前正在使用的数据库
sql
select database();
password()函数,MySQL数据库使用该函数对用户加密
sql
select password('root');
+-------------------------------------------+
| password('root') |
+-------------------------------------------+
| *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |
+-------------------------------------------+
ifnull(val1, val2) 如果val1为null,返回val2,否则返回val1的值
