MySQL中常用函数

前言

这一篇我们来看看MySQL中提供的内建函数,这些函数可以帮助我们编写简单快捷的SQL语句。

字符串函数

函数功能
CONCAT(S1, S2, …Sn)连接S1,S2,…Sn为一个字符串
INSERT(str, x, y, instr)将字符串str从第x位置开始,y个字符长度的子串替换为字符串instr
LOWER(str)将字符串str中所有字符变为小写
UPPER(str)将字符串str中所有字符变为大写
LEFT(str, x)返回字符串str最左边的x个字符
RIGHT(str, x)返回字符串str最右边的x个字符
LPAD(str, n, pad)用字符串pad对str最左边进行填充,直到长度为n个字符长度
RPAD(str, n, pad)用字符串pad对str最右边进行填充,直到长度为n个字符长度
LTRIM(str)去掉字符串str左侧的空格
RTRIM(str)去掉字符串str行尾的空格
REPEAT(str, x)返回str重复x次的结果
REPLACE(str, a, b)用字符串b替换字符串str中所有出现的字符串a
STRCMP(s1, s2)比较字符串s1和s2
TRIM(str)去掉字符串行尾和行头的空格
SUBSTRING(str, x, y)返回从字符串str的x位置起y个字符串长度的子串

字符串函数都是一些处理字符串的相关函数,下面列举一个函数的具体使用:

1
2
3
4
5
6
7
mysql> select repeat('mysql ', 3);
+---------------------+
| repeat('mysql ', 3) |
+---------------------+
| mysql mysql mysql |
+---------------------+
1 row in set (0.01 sec)

数值函数

函数功能
ABS(x)返回x的绝对值
CEIL(x)返回大于x的最小整数值
FLOOR(x)返回小于x的最大整数值
MOD(x, y)返回x/y的模
RAND()返回一个0~1内的随机数
ROUND(x, y)返回参数x的四舍五入的有y位小数的值
TRUNCATE(x, y)返回数字x截断为y位小数的结果

数值函数类似于Java中的Math类所具有的函数,下面列举一些函数的使用:

1
2
3
4
5
6
7
mysql> select mod(15, 10), mod(1, 11), mod(null, 10);
+-------------+------------+---------------+
| mod(15, 10) | mod(1, 11) | mod(null, 10) |
+-------------+------------+---------------+
| 5 | 1 | NULL |
+-------------+------------+---------------+
1 row in set (0.01 sec)
1
2
3
4
5
6
7
mysql> select rand(), rand();
+--------------------+--------------------+
| rand() | rand() |
+--------------------+--------------------+
| 0.9221980813166109 | 0.4670650264872844 |
+--------------------+--------------------+
1 row in set (0.00 sec)
1
2
3
4
5
6
7
mysql> select round(1.235, 2), truncate(1.235, 2);
+-----------------+--------------------+
| round(1.235, 2) | truncate(1.235, 2) |
+-----------------+--------------------+
| 1.24 | 1.23 |
+-----------------+--------------------+
1 row in set (0.00 sec)

日期和时间函数

函数功能
CURDATE()返回当前日期
CURTIME()返回当前时间
NOW()返回当前的日期和时间
UNIX_TIMESTAMP(date)返回日期date的UNIX时间戳
FROM_UNIXTIME返回UNIX时间戳的日期值
WEEK(date)返回日期date为一年中的第几周
YEAR(date)返回日期date的年份
HOUR(time)返回time的小时值
MINUTE(time)返回time的分钟值
MONTHNAME(date)返回date的月份名
DATE_FORMAT(date, fmt)返回按字符串fmt格式化日期的date值
DATE_ADD(date, INTERVAL expr type)返回一个日期或时间值加上一个时间间隔的时间值
DATEDIFF(expr, expr2)返回起始时间expr和结束时间expr2之间的天数

上面是对日期和时间操作的相关函数,具体用法如下:

1
2
3
4
5
6
7
mysql> select curdate(), curtime(), now();
+------------+-----------+---------------------+
| curdate() | curtime() | now() |
+------------+-----------+---------------------+
| 2019-04-30 | 21:05:22 | 2019-04-30 21:05:22 |
+------------+-----------+---------------------+
1 row in set (0.00 sec)
1
2
3
4
5
6
7
mysql> select date_format(now(), '%Y-%c-%d');
+--------------------------------+
| date_format(now(), '%Y-%c-%d') |
+--------------------------------+
| 2019-4-30 |
+--------------------------------+
1 row in set (0.00 sec)
1
2
3
4
5
6
7
mysql> select datediff(now(), '2018-01-01');
+-------------------------------+
| datediff(now(), '2018-01-01') |
+-------------------------------+
| 484 |
+-------------------------------+
1 row in set (0.00 sec)

流程函数

函数功能
IF(value, t f)如果value是真,返回t,否则返回f
IFNULL(value1, value2)如果value1不为空,返回value1,否则返回value2
CASE WHEN[value1] THEN[result]…ELSE[default]END如果value1是真,返回result,否则返回default
CASE [expr] WHEN [value] THEN[result]…ELSE[default]END如果expr等于value1,返回result,否则返回default

为了演示这些流程函数的使用,我们先建一个数据库表并插入一些数据:

1
2
3
create table salary (userid int, salary decimal(9, 2));

insert into salary values(1, 1000), (2, 2000), (3, 3000), (4, 4000), (5, 5000), (1, null);
1
2
3
4
5
6
7
8
9
10
11
12
mysql> select * from salary;
+--------+---------+
| userid | salary |
+--------+---------+
| 1 | 1000.00 |
| 2 | 2000.00 |
| 3 | 3000.00 |
| 4 | 4000.00 |
| 5 | 5000.00 |
| 1 | NULL |
+--------+---------+
6 rows in set (0.00 sec)

我们认为月薪在2000元以上的职员属于高薪,低于2000元的属于底薪,分别用heigh和low表示:

1
2
3
4
5
6
7
8
9
10
11
12
mysql> select if(salary > 2000, 'height', 'low') from salary;
+------------------------------------+
| if(salary > 2000, 'height', 'low') |
+------------------------------------+
| low |
| low |
| height |
| height |
| height |
| low |
+------------------------------------+
6 rows in set (0.00 sec)
1
2
3
4
5
6
7
8
9
10
11
12
mysql> select ifnull(salary, 0) from salary;
+-------------------+
| ifnull(salary, 0) |
+-------------------+
| 1000.00 |
| 2000.00 |
| 3000.00 |
| 4000.00 |
| 5000.00 |
| 0.00 |
+-------------------+
6 rows in set (0.00 sec)
1
2
3
4
5
6
7
8
9
10
11
12
mysql> select case when salary<=2000 then 'low' else 'heigh' end from salary;
+----------------------------------------------------+
| case when salary<=2000 then 'low' else 'heigh' end |
+----------------------------------------------------+
| low |
| low |
| heigh |
| heigh |
| heigh |
| heigh |
+----------------------------------------------------+
6 rows in set (0.00 sec)
1
2
3
4
5
6
7
8
9
10
11
12
mysql> select case salary when 1000 then 'low' when 2000 then 'mid' else 'heigh' end from salary;
+------------------------------------------------------------------------+
| case salary when 1000 then 'low' when 2000 then 'mid' else 'heigh' end |
+------------------------------------------------------------------------+
| low |
| mid |
| heigh |
| heigh |
| heigh |
| heigh |
+------------------------------------------------------------------------+
6 rows in set (0.00 sec)

其他常用函数

函数功能
DATABASE()返回当前数据库名
VERSION()返回当前数据库版本
USER()返回当前登录用户名
INET_ATON(IP)返回IP地址的数字表示
INET_NTOA(num)返回数字代表的IP地址
PASSWORD(str)返回字符串str的加密版本
MD5()返回字符串str的MD5值
1
2
3
4
5
6
7
mysql> select database(), version(), user();
+------------+-----------+--------+
| database() | version() | user() |
+------------+-----------+--------+
| test1 | 5.7.26 | root@ |
+------------+-----------+--------+
1 row in set (0.00 sec)
1
2
3
4
5
6
7
mysql> select inet_aton('192.168.1.1'), inet_ntoa(3232235777);
+--------------------------+-----------------------+
| inet_aton('192.168.1.1') | inet_ntoa(3232235777) |
+--------------------------+-----------------------+
| 3232235777 | 192.168.1.1 |
+--------------------------+-----------------------+
1 row in set (0.00 sec)
1
2
3
4
5
6
7
mysql> select password('123456'), md5('123456');
+-------------------------------------------+----------------------------------+
| password('123456') | md5('123456') |
+-------------------------------------------+----------------------------------+
| *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | e10adc3949ba59abbe56e057f20f883e |
+-------------------------------------------+----------------------------------+
1 row in set, 1 warning (0.00 sec)