字符串函数
- ASCII(char):返回字符的ASCII码值。
- BIT_LENGTH(str):返回字符串的比特长度。
- CONCAT(s1,s2…,sn):将s1,s2…,sn连接成字符串。任何字符串与NULL连接的结果都是NULL。
- CONCAT_WS(sep,s1,s2…,sn) 将s1,s2…,sn连接成字符串,并用sep字符间隔。
- INSERT(str,x,y,instr) 将字符串str从第x位置开始,y个字符长的子串替换为字符串instr
- FIND_IN_SET(str,list) 分析逗号分隔的list列表,如果发现str,返回str在list中的位置
- LCASE(str)或LOWER(str) 返回将字符串str中所有字符改变为小写后的结果。
- UCASE(str)或UPPER(str) 返回将字符串str中所有字符转变为大写后的结果。
- LEFT(str,x) 返回字符串str中最左边的x个字符。如果第二个参数为NULL,则不返回任何字符串。
- RIGHT(str,x) 返回字符串str中最右边的x个字符。如果第二个参数为NULL,则不返回任何字符串。
- LENGTH(str) 返回字符串str中的字符数。
- POSITION(substr,str) 返回子串substr在字符串str中第一次出现的位置。
- REPEAT(str,srchstr,rplcstr) 返回字符串str重复x次的结果。
- REVERSE(str) 返回颠倒字符串str的结果。
- LTRIM(str) 去掉字符串str开头的空格
- RTRIM(str) 去掉字符串str尾部的空格
- TRIM(str) 去除字符串首部和尾部的所有空格。
- replace(str,a,b):用字符串b替换str中所有出现的字符串a。
- strcmp(s1,s2):比较两个字符串的ASCII码值的大小。
- substring(str,x,y):返回子串。
数值函数
- ABS(x) 返回x的绝对值
- BIN(x) 返回x的二进制(OCT返回八进制,HEX返回十六进制)
- EXP(x) 返回值e(自然对数的底)的x次方
- GREATEST(x1,x2,…,xn) 返回集合中最大的值
- LEAST(x1,x2,…,xn) 返回集合中最小的值
- LOG(x,y) 返回x的以y为底的对数
- MOD(x,y) 返回x/y的模(余数),任意一个操作数是NULL就返回NULL。
- PI() 返回pi的值(圆周率)
- RAND() 返回0到1内的随机值,可以通过提供一个参数(种子)使RAND()随机数生成器生成一个指定的值。
- FLOOR(x) 返回小于x的最大整数值,(去掉小数取整)
- CEILING(x) 返回大于x的最小整数值,(进一取整)
- ROUND(x,y) 返回参数x的四舍五入的有y位小数的值,(四舍五入)。如果不写y,则默认y为0
- TRUNCATE(x,y) 返回数字x截断为y位小数的结果
- SIGN(x) 返回代表数字x的符号的值(正数返回1,负数返回-1,0返回0)
- SQRT(x) 返回一个数的平方根
日期和时间函数
- DATE_FORMAT(date,fmt) 依照指定的fmt格式格式化日期date值
- MONTHNAME(date) 返回date的月份名(英语月份,如October)
- DAYNAME(date) 返回date的星期名(英语星期几,如Saturday)
- NOW() 返回当前的日期和时间 (2016-10-08 18:57:39)。
- CURDATE()或CURRENT_DATE() 返回当前的日期(年月日)。
- CURTIME()或CURRENT_TIME() 返回当前的时间(时分秒)。
- QUARTER(date) 返回date在一年中的季度(1~4)
- WEEK(date) 返回日期date为一年中第几周(0~53)
- DAYOFYEAR(date) 返回date是一年的第几天(1~366)
- DAYOFMONTH(date) 返回date是一个月的第几天(1~31)
- DAYOFWEEK(date) 返回date所代表的一星期中的第几天(1~7)
- YEAR(date) 返回日期date的年份(1000~9999)
- MONTH(date) 返回date的月份值(1~12)
- DAY(date) 返回date的天数部分
- HOUR(time) 返回time的小时值(0~23)
- MINUTE(time) 返回time的分钟值(0~59)
- SECOND(time) 返回time的秒值(0-59)
- DATE(datetime) 返回datetime的日期值
- TIME(datetime) 返回datetime的时间值
- datediff(d1,d2) 计算两个日期之间相差的天数
- DATE_ADD(date,INTERVAL int keyword) 返回日期date加上间隔时间int的结果(int必须按照关键字进行格式化),如:SELECT DATE_ADD(CURRENT_DATE(),INTERVAL 6 MONTH);
- DATE_SUB(date,INTERVAL int keyword) 返回日期date减去间隔时间int的结果(int必须按照关键字进行格式化),如:SELECT DATE_SUB(CURRENT_DATE(),INTERVAL 6 MONTH);
流程函数
实现条件选择
下面创建一个职员薪水的表,进行说明:
mysql> create table salary (
-> userid int,
-> salary decimal(9,2)
-> );
Query OK, 0 rows affected (0.02 sec)
mysql> alter table salary modify userid int primary key;
Query OK, 0 rows affected (0.03 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> alter table salary modify userid int auto_increment;
Query OK, 0 rows affected (0.02 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> desc salary;
+--------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+--------+--------------+------+-----+---------+----------------+
| userid | int(11) | NO | PRI | NULL | auto_increment |
| salary | decimal(9,2) | YES | | NULL | |
+--------+--------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)
进行初始化表:
mysql> insert into salary(salary) values(1000),(2000),(3000),(4000),(5000),(null);
Query OK, 6 rows affected (0.01 sec)
Records: 6 Duplicates: 0 Warnings: 0
mysql> select * from salary;
+--------+---------+
| userid | salary |
+--------+---------+
| 1 | 1000.00 |
| 2 | 2000.00 |
| 3 | 3000.00 |
| 4 | 4000.00 |
| 5 | 5000.00 |
| 6 | NULL |
+--------+---------+
6 rows in set (0.00 sec)
mysql> select if(salary>1000,'high','low') from salary;
+------------------------------+
| if(salary>1000,'high','low') |
+------------------------------+
| low |
| high |
| high |
| high |
| high |
| low |
+------------------------------+
6 rows in set (0.00 sec)
替换NULL值:
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)
mysql> select case when salary<=2000 then 'low' else 'high' end from salary;
+---------------------------------------------------+
| case when salary<=2000 then 'low' else 'high' end |
+---------------------------------------------------+
| low |
| low |
| high |
| high |
| high |
| high |
+---------------------------------------------------+
6 rows in set (0.00 sec)
mysql> select case salary when 1000 then 'low' when 2000 then 'mid' else 'high' end from salary;
+-----------------------------------------------------------------------+
| case salary when 1000 then 'low' when 2000 then 'mid' else 'high' end |
+-----------------------------------------------------------------------+
| low |
| mid |
| high |
| high |
| high |
| high |
+-----------------------------------------------------------------------+
6 rows in set (0.00 sec)
聚合函数
常用于GROUP BY从句的SELECT查询中
下面五个函数会忽略值为NULL的行
- AVG(col) 返回指定列的平均值
- COUNT(col) 返回指定列中非NULL值/行的个数(当函数参数为星号*时不会忽略)
- MIN(col) 返回指定列的最小值
- MAX(col) 返回指定列的最大值
- SUM(col) 返回指定列的所有值之和
其他常用函数
mysql> select database();
+------------+
| database() |
+------------+
| test |
+------------+
1 row in set (0.00 sec)
mysql> select version();
+------------+
| version() |
+------------+
| 5.7.18-log |
+------------+
1 row in set (0.00 sec)
mysql> select user();
+----------------+
| user() |
+----------------+
| root@localhost |
+----------------+
1 row in set (0.00 sec)
返回IP地址的网络字节序表示:
mysql> select inet_aton('192.168.1.1');
+--------------------------+
| inet_aton('192.168.1.1') |
+--------------------------+
| 3232235777 |
+--------------------------+
1 row in set (0.00 sec)
返回网络字节序代表的IP地址:
mysql> select inet_ntoa(11111);
+------------------+
| inet_ntoa(11111) |
+------------------+
| 0.0.43.103 |
+------------------+
1 row in set (0.01 sec)
mysql> select md5('123');
+----------------------------------+
| md5('123') |
+----------------------------------+
| 202cb962ac59075b964b07152d234b70 |
+----------------------------------+
1 row in set (0.00 sec)