函数的分类
- 从函数定义的角度出发,可以将函数分成内置函数和自定义函数。内置函数是系统内置的通用函数,自定义函数是我们根据自己的需要编写的
- 内置函数可以再分为两类:单行函数和聚合函数(分组函数)
- 单行函数的特点:
- 只对一行进行变换,每行返回一个结果
- 参数可以是一列或一个值
- 可以嵌套
数值函数
基本函数
| 函数 | 用法 |
|---|---|
| ABS(x) | 返回x的绝对值 |
| SIGN(x) | 返回x的符号,正数返回1,负数返回-1,0返回0 |
| PI() | 返回圆周率的值 |
| CEIL(x),CEILING(x) | 返回大于或等于某个值的最小整数 |
| FLOOR(x) | 返回小于或等于某个值的最大整数 |
| LEAST(e1, e2, e3…) | 返回列表中的最小值 |
| GREATEST(e1, e2, e3…) | 返回列表中的最大值 |
| MOD(x, y) | 返回X除以Y后的余数 |
| RAND() | 返回0~1的随机值 |
| RAND(x) | 返回0~1的随机值,其中x的值用作种子值,相同的x值会产生相同的随机数 |
| ROUND(x) | 返回一个对x的值进行四舍五入后,最接近于X的整数 |
| ROUND(x, y) | 返回一个对x的值进行四舍五入后最接近X的值,并保留到小数点后面Y位 |
| TRUNCATE(x, y) | 返回数字x截断为y位小数的结果 |
| SQRT(x) | 返回x的平方根。当X的值为负数时,返回NULL |

角度与弧度互换函数
| 函数 | 用法 |
|---|---|
| RADIANS(x) | 将角度转化为弧度,其中,参数x为角度值 |
| DEGREES(x) | 将弧度转化为角度,其中,参数x为弧度值 |
三角函数
| 函数 | 用法 |
|---|---|
| SIN(x) | 返回x的正弦值,其中,参数x为弧度值 |
| ASIN(x) | 返回x的反正弦值,即获取正弦为x的值。如果x的值不在-1到1之间,则返回NULL |
| COS(x) | 返回x的余弦值,其中,参数x为弧度制 |
| ACOS(x) | 返回x的反余弦值,即获取余弦为x的值。如果x的值不在-1到1之间,则返回NULL |
| TAN(x) | 返回x的正切值,其中,参数x为弧度制 |
| ATAN(x) | 返回x的反正切值,即返回正切值为x的值 |
| ATAN2(m, n) | 返回两个参数的反正切值 |
| COT(x) | 返回x的余切值,其中,x为弧度值 |
指数与对数
| 函数 | 用法 |
|---|---|
| POW(x, y),POWER(x, y) | 返回x的y次方 |
| EXP(x) | 返回e的x次方,其中e是一个常数,2.718281828459045 |
| LN(x),LOG(x) | 返回以e为底的x的对数,当x <= 0 时,返回NULL |
| LOG10(x) | 返回以10为底的x的对数,当x <= 0 时,返回NULL |
| LOG2(x) | 返回以2为底的x的对数,当x <= 0 时,返回NULL |
进制间的转换
| 函数 | 用法 |
|---|---|
| BIN(x) | 返回x的二进制编码 |
| HEX(x) | 返回x的十六进制编码 |
| OCT(x) | 返回x的八进制编码 |
| CONV(x, f1, f2) | 返回f1进制数变成f2进制数 |
字符串函数
注意:MySQL中,字符串的索引是从1开始的
| 函数 | 用法 |
|---|---|
| ASCII(s) | 返回字符串s中的第一个字符的ASCII码值 |
| CHAR_LENGTH(s) | 返回字符串s的字符数。作用与CHARACTER_LENGTH(s)相同 |
| LENGTH(s) | 返回字符串s的字节数,和字符集有关 |
| CONCAT(s1, s2, ……, sn) | 连接s1, s2, ……, sn为一个字符串 |
| CONCAT_WS(x, s1, s2, ……, sn) | 同CONCAT(s1, s2, …, sn)函数,但是每个字符串之间要加上x |
| INSERT(str, idx, len, replacestr) | 将字符串str从第idx位置开始,len个字符长的子串替换为字符串replacestr |
| REPLACE(str, a, b) | 用字符串b替换字符串str中所有出现的字符串a |
| UPPER(s) 或 UCASE(s) | 将字符串s的所有字母转成大写字母 |
| LOWER(s) 或 LCASE(s) | 将字符串s的所有字母转成小写字母 |
| LEFT(str, n) | 返回字符串str最左边的n个字符 |
| RIGHT(str, n) | 返回字符串str最右边的n个字符 |
| LPAD(str, len, pad) | 用字符串pad对str最左边进行填充,直到str的长度为len个字符 |
| RPAD(str, len, pad) | 用字符串pad对str最右边进行填充,直到str的长度为len个字符 |
| LTRIM(s) | 去掉字符串s左侧的空格 |
| RTRIM(s) | 去掉字符串s右侧的空格 |
| TRIM(s) | 去掉字符串s开始与结尾的空格 |
| TRIM(s1 FROM s) | 去掉字符串s开始与结尾的s1 |
| TRIM(LEADING s1 FROM s) | 去掉字符串s开始处的s1 |
| TRIM(TRAILING s1 FROM s) | 去掉字符串s结尾处的s1 |
| REPEAT(str, n) | 返回str重复n次的结果 |
| SPACE(n) | 返回n个空格 |
| STRCMP(s1, s2) | 比较字符串s1,s2的ASCII码值的大小 |
| SUBSTR(s, index, len) | 返回从字符串s的index位置其len个字符 作用与SUBSTRING(s, n, len)、 MID(s, n, len)相同 |
| LOCATE(substr, str) | 返回字符串substr在字符串str中首次出现的位置。未找到,返回0 作用与POSITION(substr IN str)、INSTR(str, substr)相同 |
| ELT(m, s1, s2, …, sn) | 返回指定位置的字符串 如果m=1,则返回s1,如果m=2,则返回s2,如果m=n,则返回sn |
| FIELD(s, s1, s2, …, sn) | 返回字符串s在字符串列表中第一次出现的位置 |
| FIND_IN_SET(s1, s2) | 返回字符串s1在字符串s2中第一次出现的位置。其中,字符串s2是一个以逗号分隔的字符串 |
| REVERSE(s) | 返回s反转后的字符串 |
| NULLIF(value1, value2) | 比较两个字符串,如果value1与value2相等,则返回NULL,否则返回value1 |
日期和时间函数
流程控制函数
| 函数 | 用法 |
|---|---|
| IF(value, value1, value2) | 如果value的值为TRUE,返回value1,否则返回value2 |
| IFNULL(value1, value2) | 如果value1不为NULL,返回value1,否则返回value2 |
| CASE WHEN 条件1 THEN 结果1 WHEN 条件2 THEN 结果2 … [ELSE resultn] END |
相当于Java的if…else if…else… |
| CASE expr WHEN 常量值1 THEN 值1 WHEN 常量值2 THEN 值2 … [ELSE 值n] END |
相当于Java的switch…case… |
SELECT last_name, salary, IF(salary >= 6000, '高工资', '低工资') "details"FROM employees;SELECT last_name, commission_pct, IF(commisssion_pct IS NOT NULL, commission_pct, 0) "details"salary * 12 * (1 + IF(commisssion_pct IS NOT NULL, commission_pct, 0)) "annual_sal"FROM employees;SELECT last_name, commission_pct, IFNULL(commission_pct, 0) "details"FROM employees;SELECT employee_id,salary, CASE WHEN salary >= 15000 THEN '高薪'WHEN salary >= 10000 THEN '潜力股'WHEN salary >= 8000 THEN '屌丝'ELSE '草根' END "details"FROM employees;SELECT last_name, job_id, salary,CASE job_id WHEN 'IT_PROG' THEN 1.10 * salaryWHEN 'ST_CLERK' THEN 1.15 * salaryWHEN 'SA_REP' THEN 1.20 * salaryELSE salary END "REVISED_SALARY"FROM employees;
加密与解密函数
| 函数 | 用法 |
|---|---|
| PASSWORD(str) | 返回字符串str的加密版本,41位长的字符串。加密结果不可逆,常用于用户的密码加密 |
| MD5(str) | 返回字符串str的md5加密后的值,也是一种加密方式。若参数为NULL,则返回NULL |
| SHA(str) | 从原明文密码str计算并返回加密后的密码字符串,当参数为 NULL时,返回NULL。SHA加密算法比MD5更加安全 |
| ENCODE(value, password_seed) | 返回使用password_seed作为加密密码加密value |
| DECODE(value, password_seed) | 返回使用password_seed作为加密密码解密value |
MySQL信息函数
| 函数 | 用法 |
|---|---|
| VERSION() | 返回当前MySQL的版本号 |
| CONNECTION_ON() | 返回当前MySQL服务器的连接数 |
| DATABASE()、SCHEMA() | 返回MySQL命令行当前所在的数据库 |
| USER()、CURRENT_USER()、 SYSTEM_USER()、SESSION_USER() |
返回当前连接MySQL的用户名,返回结果格式为”主机名@用户名” |
| CHARSET(value) | 返回字符集value自变量的字符集 |
| COLLATION(value) | 返回字符串value的比较规则 |
其他函数
| 函数 | 用法 |
|---|---|
| FORMAT(value, n) | 返回对数字value进行格式化后的结果数据,n表示四舍五入后保留到小数点后n位 |
| CONV(value, from, to) | 将value的值进行不同进制之间的转换 |
| INET_ATON(ipvalue) | 将以点分隔的IP地址转化为一个数字 |
| INET_NTOA(value) | 将数字形式的IP地址转化为以点分隔的IP地址 |
| BENCHMARK(n, expr) | 将表达式expr重复执行n次,用于测试MySQL处理expr表达式所耗费的时间 |
| CONVERT(value USING char_code) | 将value所使用的字符编码修改为char_code |
