函数

一、数学函数

1、绝对值函数ABS(x):

x为插入的数据,返回绝对值

2、返回圆周率函数PI():

无需插入数据,返回圆周率的值,默认为小数点后6位

3、平方根函数SQRT(x):

返回非负数的二次根

4、求余函数MOD(x,y):

返回x被y除后的余数,对小数点也有作用,返回除数运算后的精确除数

5、获取整数函数GEIL(x)、GEILING(x)、FLOOR(x):

(1)GEIL(x)和GEILING(x)意义相同,返回不小于x的最小整数值,返回值是一个bigint类型。
(2)FLOOR(x)返回不大于x的最大整数值,返回值是一个bigint类型

6、获取随机数函数RAND():无需加入数据,随机产生0到1之间的浮点值([0,1.0])

注意:当输入数据x时,x相同时,产生的随机数相同
实例:



无数据x
mysql> select rand(),rand();
+--------------------+---------------------+
| rand()             | rand()              |
+--------------------+---------------------+
| 0.6126245340449964 | 0.16587338705162832 |
+--------------------+---------------------+
有数据x
mysql> select rand(),rand(1),rand(1),rand(2);
+--------------------+---------------------+---------------------+--------------------+
| rand()             | rand(1)             | rand(1)             | rand(2)            |
+--------------------+---------------------+---------------------+--------------------+
| 0.4598466888627472 | 0.40540353712197724 | 0.40540353712197724 | 0.6555866465490187 |
+--------------------+---------------------+---------------------+--------------------+



7、四舍五入函数ROUND(x)、ROUND(x,y)、TRUNCATE(x,y):

(1)ROUND(x):对x值进行四舍五入。
(2)ROUND(x,y):
1)y大于0,进行四舍五入,其值保留到小数点后面的y位。
2)y小于0,则保留x到小数点左边y位,并且保留到小数点左边的相应位数直接保存位0,不进行四舍五入。
实例



mysql> select round(1.38,1),round(1.38,0),round(211.38,-1),round(211.38,-2),round(1.38,-2);
+---------------+---------------+------------------+------------------+----------------+
| round(1.38,1) | round(1.38,0) | round(211.38,-1) | round(211.38,-2) | round(1.38,-2) |
+---------------+---------------+------------------+------------------+----------------+
|           1.4 |             1 |              210 |              200 |              0 |
+---------------+---------------+------------------+------------------+----------------+



(3)TRUNCATE(x,y):
1)返回被舍弃至小数点后y位的数字x。
2)若y的值为0,则结果不带有小数部分。
3)若y是负数,则截去(归零)x小数点左起第y位开始后面所有低位的值
实例



mysql> select truncate(1.31,1),truncate(1.31,0),truncate(12.31,-1);
+------------------+------------------+--------------------+
| truncate(1.31,1) | truncate(1.31,0) | truncate(12.31,-1) |
+------------------+------------------+--------------------+
|              1.3 |                1 |                 10 |
+------------------+------------------+--------------------+



注意:round(x,y)和truncate(x,y)的区别
round(x,y)取值时会进行四舍五入;
Truncate(x,y)取值时是直接四舍五入。

8、符号函数SIGN(x):x为负时返回-1,x为零时返回0,x为正时返回1。

9、幂函数POW(x,y)、POWER(x,y)、EXP(x):

1)POW(x,y)和POWER(x,y):返回x的y次乘方的结果值
2)EXP(x):返回e的x乘方后的值

10、对数函数LOG(x)、LOG10(x):

1)LOG(x):返回x的自然对数,x相对于基数e的对数
2)LOG10(x):返回x的基数为10的对数

11、角度与弧度转化函RADIANS(x)、DEGREES(x):

1)RADIANS(x):将参数x由角度转化为弧度
2)DEGREES(x):将参数x由弧度转为角度

12、正弦函数SIN(x):返回x的正弦,其中x为弧度值

13、反正弦函数ASIN(x):返回x的反正弦,即正弦x的值,若x不在-1到1之间,则返回null。
14、余数函数COS(x):返回x的余弦,其中x为弧度值
15、反余数函数ACOS(x):返回x的反余弦,即余弦x的值,若x不在-1到1之间,则返回null。
16、正切函数TAN(x):返回x的正切,其中x为弧度值
17、反正切函数ATAN(x):返回x的反切弦,即正切x的值,
18、余切函数COT(x):返回x的余切

二、字符串函数

1、计算字符串中的字符个数CHAR_LENGTH(‘str’):

作用:返回字符串str的字符个数;
注意:一个多字节字符算作一个单字符。
实例



mysql> select char_length('运'),char_length('yun'),char_length('123');
+-------------------+--------------------+--------------------+
| char_length('运') | char_length('yun') | char_length('123') |
+-------------------+--------------------+--------------------+
|                 1 |                  3 |                  3 |
+-------------------+--------------------+--------------------+



2、计算字符串中的字节长度LENGTH(‘str’):

作用:返回字符串的字节长度;
注意:使用utf8编码字符级时,一个汉字是3个字节,一个数字或字母算一个字节。
实例



mysql> select length('运'),length('yun'),length('123');
+--------------+---------------+---------------+
| length('运') | length('yun') | length('123') |
+--------------+---------------+---------------+
|            2 |             3 |             3 |
+--------------+---------------+---------------+



3、合并字符串函数CONCAT(‘s1’,’s2’…):CONCAT_WS(‘x’,’s1’,’s2’):

 (1)CONCAT(‘s1’,’s2’…):
作用:返回结果为一个或多个字符串连接产生新的字符串。
注意:
  1)如果任何一个原字符串为空值,则返回空值;
  2)如果任何一个原字符串为二进制,则返回二进制;
  3)如果任何一个原字符串为非二进制,则返回非二进制;
实例



mysql> select concat('my','sql'),concat('null','sql'),concat(null,'null');
+--------------------+----------------------+---------------------+
| concat('my','sql') | concat('null','sql') | concat(null,'null') |
+--------------------+----------------------+---------------------+
| mysql              | nullsql              | NULL                |
+--------------------+----------------------+---------------------+



(2)CONCAT_WS(‘x’,’s1’,’s2’):
   注意:
     1)x为分隔符,其位置在要连接的字符串之间;
     2)分隔符可以是字符串,也可以是其他符号;
     3)如果分隔符是空值,则返回空值;
     4)函数任何分隔符的原字符串后如果是的空值则返回空值。
实例



mysql> select concat_ws('*','my','sql'),concat_ws('null','my','sql'),concat('*','m',null,'y');
+---------------------------+------------------------------+--------------------------+
| concat_ws('*','my','sql') | concat_ws('null','my','sql') | concat('*','m',null,'y') |
+---------------------------+------------------------------+--------------------------+
| my*sql                    | mynullsql                    | NULL                     |
+---------------------------+------------------------------+--------------------------+



4、替换字符串函数INSERT(原字符串,开始位置,替换长度,用来替换的字符串):

注意:
1)如果开始位置大于原字符串的位置或者小于等于0,则返回原字符串;
2)如果替换字符串超过原字符串长度,则替换x后面的所有字符串;
3)四个参数有一个是空值,则都是空值。
4)看例题,描述不出来。
实例



mysql> select insert('qwert',2,1,'asdf'),insert('qwert',2,10,'asdf'),insert('qwert',null,2,'asdf');
+----------------------------+-----------------------------+-------------------------------+
| insert('qwert',2,1,'asdf') | insert('qwert',2,10,'asdf') | insert('qwert',null,2,'asdf') |
+----------------------------+-----------------------------+-------------------------------+
| qasdfert                   | qasdf                       | NULL                          |
+----------------------------+-----------------------------+-------------------------------+



5、字母大小写转换函数

1)转小写:LOWER(‘str’)和LCASE(‘str’):
2)转大写:UPPER(‘str’)和UCASE(‘str’):

6、获取指定长度的字符串的函数

1)LEFT(‘str’,n):返回字符串str开始最左边n个字符;
2)RIGHT(‘str’,n):返回字符串str开始最右边n个字符;

7、填充字符串的函数

(1)LPAD(str1,len,str2):
    1)作用:返回str1,其左边由字符串str2填补到len字符长度。
    2)注意:假如str1的长度大于len,则返回值被缩短到len字符。
(2)RPAD(str1,len,str2):
    1)作用:返回str1,其右边由字符串str2填补到len字符长度。
    2)注意:假如str1的长度大于len,则返回值被缩短到len字符。

8、删除空格的函数LTRIM():RTRIM():TRIM():

    LTRIM(str):字符串str只有左侧空格字符被删除
    RTRIM(str):字符串str只有右侧空格字符被删除
    TRIM(str):字符串str两侧空格字符被删除

9、删除指定字符串的函数TRIM( str1 FROM str):

作用:删除字符串str中两端所有的子字符串str1.str1为可选项,在未指定情况下删除空格。

10、重复生成字符串的函数REPEAT(str,n):

作用:返回一个由重复的字符串str组成的字符串,字符串str的数目等于n。若n<=0,则返回一个空字符串。若str或n为null,则返回null。

11、空格函数SPACE(n):

作用:返回一个由n个空格组成的字符串。
【例】为便于显示使用concat()函数;



mysql> select concat('(',space(3),')');
+--------------------------+
| concat('(',space(3),')') |
+--------------------------+
| (   )                    |
+--------------------------+



12、替换函数REPLACE(str,str1,str2):

作用:使用字符串str2替换字符串str中的所有字符串str1;

13、比较字符串大小的函数STRCMP(str1,str2):

作用:str1与str2结果相同返回0;str1小于str2,返回-1;其他结果返回1;

14、获取子字符串函数SUBSTRING(s,n,长度len):MID(s,n,长度len):

作用:两者的作用差不多;
如果len为正数,则从字符串str开始方向的起始位置n返回一个长度为len的字符;
如果len为负数,则从字符串str结束方向的起始位置n返回一个长度为len的字符;
实例



mysql> select substring('hahayixiaorenshengrumeng',5,3),
    -> substring('hahayixiaorenshengrumeng',-5,3);
+-------------------------------------------+--------------------------------------------+
| substring('hahayixiaorenshengrumeng',5,3) | substring('hahayixiaorenshengrumeng',-5,3) |
+-------------------------------------------+--------------------------------------------+
| yix                                       | ume                                        |
+-------------------------------------------+--------------------------------------------+



注意:如果len为小于1 的数放回空值;

15、匹配字符串开始位置的函数LOCATE(str1,str),POSITION(str in str),INSTR(str,str1):

作用:三者的作用差不多;返回字符串str1在字符串str的位置

16、字符串逆序的函数REVERSE(str):

作用:将字符串str反转输出。

17、返回指定位置的字符串函数ELT(N,str1,str2,str3,str4……):

作用:若N=1,则返回字符串1;
若N=2,则返回字符串2;
如果N<1或者N>字符串的个数,则返回值时空值。

18、返回指定字符串位置的函数FIELD(str,str1,str2,str3,str4……):

作用:返回字符串str在列表中第一次出现的位置,
      找不到返回0
      Str为空值返回0,原因是空值不能和任何值进行比较;
实例



mysql> select field('ha','haa','aha','ha'),
    -> field('hhaa','haa','aha','ha'),
    -> field('','haa','aha','ha');
+------------------------------+--------------------------------+----------------------------+
| field('ha','haa','aha','ha') | field('hhaa','haa','aha','ha') | field('','haa','aha','ha') |
+------------------------------+--------------------------------+----------------------------+
|                            3 |                              0 |                          0 |
+------------------------------+--------------------------------+----------------------------+



19、返回字符串的位置FIND_IN_SET(str,str1):

作用:返回字符串str在列表中第一次出现的位置,str1为由‘,’组成的列表;
      找不到返回0
      Str为空值返回0,原因是空值不能和任何值进行比较;
      如果str1开始有‘,’则报错;
实例



mysql> select find_in_set('ha','haa,aha,ha'),
    -> find_in_set('hhaa','haa,aha,ha'),
    -> find_in_set('','haa,aha,ha');
+--------------------------------+----------------------------------+------------------------------+
| find_in_set('ha','haa,aha,ha') | find_in_set('hhaa','haa,aha,ha') | find_in_set('','haa,aha,ha') |
+--------------------------------+----------------------------------+------------------------------+
|                              3 |                                0 |                            0 |
+--------------------------------+----------------------------------+------------------------------+



20、选取字符串的函数MAKE_SET(bite,str1,str2……):

作用:返回一个设定值(含子字符串分隔字符串","字符),在设置位的相应位的字符串。str1对应于位0,str2到第1位,依此类推。在str1,str1有NULL值,...那么不添加到结果。
实例



mysql> SELECT MAKE_SET(1,'a','b','c') as a,
    -> MAKE_SET(1 | 4,'hello','nice','world') as b,
    -> MAKE_SET(1 | 4,'hello','nice',NULL,'world') as c,
    -> MAKE_SET(0,'a','b','c') as d;
+---+-------------+-------+---+
| a | b           | c     | d |
+---+-------------+-------+---+
| a | hello,world | hello |   |
+---+-------------+-------+---+



 解释:
SELECT MAKE_SET(1 | 4,'hello','nice','world');
1|4是 1和4“或运算”,得0101,将这个二进数倒过来写,从左到右,由低位到高位写,为1010。
对应字符串排列为
hello,nice,world,对应着从低位到高位的1,2,4(只有3位),取出1对应的字符串
所以,1(hello)0(nice)1(world)0,对应hello,word

三、日期和时间函数

1、获取当前日期的函数

语法:select CURDATE()\CURRENT_DATE()\utc_date();
注意:返回的日期格式为’YYYY-MM-DD’

2、获取当前时间的函数

语法:select CURTIME()\CURRENT_TIME()\utc_time();
注意:返回的时间格式为’HH:MM:SS’

3、获取当前日期和时间的函数

语法:select CURRENT_TIMESTAMP()\LOCALTIME()\NOW()\SYSDATE():
注意:返回格式:’YYYY-MM-DD HH:MM:SS’

4、UNIX时间戳函数

获取月份的函数
date的格式为YYYY-MM-DD或者YY-MM-DD
语法:select MONTH(‘date’):返回阿拉伯数字月份
语法:select MONTHHAME(‘date’):返回英文月份

5、获取星期的函数

语法:select DAYNAME(‘date’):返回英文的星期
语法:select DAYOFWEEK(‘date’):返回阿拉伯数字(1是周日,2是周一,……,7是周六)
语法:select WEEKDAY(‘date’):返回阿拉伯数字(0是周一,1是周一……,6是周六)

6、获取星期数的函数

语法:select WEEK(‘date’,Mode);
语法:select WEEKOFYEAR(‘date’,Mode);
Week函数中Mode参数取值
Mode 一周的第一天 范围
0或4 周日 0~53
1或5 周日 0~53
2或6 周日 1~53
3或7 周日 1~53

7、获取天数的函数

语法:select DAYOFYEAR(‘date’):返回date一年中的第几天,范围是1~366。
语法:select DAYOFMONTH(‘date’):返回date一个月中第几天,范围是1~31。

8、获取年份、季度、小时、分钟和秒钟的函数

 ①获取年份
  语法:select YEAR(‘date’)返回相应的年份,‘00~69’返回‘2000~2069’;‘70~99’返回‘1970~1999’
 ②获取季度
  语法:select QUARTER(‘date’)返回相应的季度,返回值在1~4
 ③获取小时
  语法:select HOUR(‘date’),返回值在0~59.
 ④获取分钟
  语法:select MINUTE(‘date’),返回值在0~59.
 ⑤获取秒值
  语法:select SECOND(‘date’),返回值在0~59.

9、截取日期的指定值的函数

语法:EXTRACT(type FROM ‘date’)
type:year截取年份                              type:month截取月份
type:day截取天数                     type:year_month截取年份和月份                type:day_hour截取小时                         type:day_minute截取分钟
type:day_second截取秒数                       type:hour_minute截取小时和分钟
type:minute_second截取分秒                    type:hour_second截取时分秒

10、时间和秒钟转化的函数

 时间转秒数
 语法:select time_to_sec(‘date’):
 秒数转时间:select sec_to_time(int);

11、计算日期和时间的函数

type:指定从起始日期添加或减去的时间间隔
日期加运算:date_add(date,interval 

12、日期和时间格式化函数Date_Format(date,format)

四、条件判断函数

1、IF函数
2、CASE函数

五、加密函数

1、加密函数PASSWORD(str)
2、加密函数MD5(str)
3、加密函数ENCODE(str,pswd_str)
4、解密函数DECODE(crypt_str,pswd_str)

六、系统信息函数

1、获取MySQL版本号;
语法:select version();
2、获取MySQL连接数
语法:
3、获取MySQL数据库名
4、获取用户名函数
5、获取字符串的字符集合和排序方式的函数
6、获取最后一个自动生成的ID值的函数
 (1)一次插入一条记录
 (2)一次插入多个记录

七、其他函数

1、格式化函数FORMAT(x,n)

FORMAT(x,n)将数字x格式化,并以四舍五入的方式保留小数点后n位,结果以字符串形式返回。
若n为零或负数,则返回结果函数不含小数部分。
【例】



mysql> select format(2.34443,2),format(2.3432,0),format(2342.3432,-2);
+-------------------+------------------+----------------------+
| format(2.34443,2) | format(2.3432,0) | format(2342.3432,-2) |
+-------------------+------------------+----------------------+
| 2.34              | 2                | 2,342                |
+-------------------+------------------+----------------------+



2、不同进制的数字进行转换的函数CONV(N,原进制,显示进制)

返回值为数值型的字符串表示,三个参数有一个为null,则返回值为null
最小基数为2,最大基数为36;
【例】



mysql> select conv('a',16,2),conv('10',10,2);
+----------------+-----------------+
| conv('a',16,2) | conv('10',10,2) |
+----------------+-----------------+
| 1010           | 1010            |
+----------------+-----------------+



3、IP地址与数字相互转换的函数INET_ATON(expr),INET_NTOA(expr)

INET_ATON(expr):将一个字符串的网络地址的点地址转化为一个代表该地址(4或8比特)数值的整数。 INET_NTOA(expr):将一个地址(4或8比特)数值的整数转换为一个字符串的网络地址的点地址;
【例】



INET_ATON(expr):
mysql> select INET_ATON('211.52.175.185');
+-----------------------------+
| INET_ATON('211.52.175.185') |
+-----------------------------+
|                  3543445433 |
+-----------------------------+
INET_NTOA(expr):
mysql> select INET_NTOA(3543445433);
+-----------------------+
| INET_NTOA(3543445433) |
+-----------------------+
| 211.52.175.185        |
+-----------------------+



注意:两者的计算方式
211*(256^3)+52*(256^2)+175*(256^1)+185=3543445433;
4、加锁函数和解锁函数
5、重复执行指定操作的函数
6、改变字符集的函数
7、改变数据类型的函数