Mysql学习Mysql常用函数
Posted Gtea
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql学习Mysql常用函数相关的知识,希望对你有一定的参考价值。
一、数学函数
ABS(x)
返回x的绝对值BIN(x)
返回x的二进制(OCT返回八进制,HEX返回十六进制)CEILING(x)
返回大于x的最小整数值EXP(x)
返回值e(自然对数的底)的x次方FLOOR(x)
返回小于x的最大整数值GREATEST(x1,x2,...,xn)
返回集合中最大的值LEAST(x1,x2,...,xn)
返回集合中最小的值LN(x)
返回x的自然对数LOG(x,y)
返回x的以y为底的对数MOD(x,y)
返回x/y的模(余数)PI()
返回pi的值(圆周率)RAND()
返回0到1内的随机值,可以通过提供一个参数(种子)使RAND()随机数生成器生成一个指定的值。ROUND(x,y)
返回参数x的四舍五入的有y位小数的值SIGN(x)
返回代表数字x的符号的值SQRT(x)
返回一个数的平方根TRUNCATE(x,y)
返回数字x截短为y位小数的结果
二、聚合函数(常用于GROUP BY从句的SELECT查询中)
AVG(col)
返回指定列的平均值COUNT(col)
返回指定列中非NULL值的个数MIN(col)
返回指定列的最小值MAX(col)
返回指定列的最大值SUM(col)
返回指定列的所有值之和GROUP_CONCAT(col)
返回由属于一组的列值连接组合而成的结果
三、字符串函数
ASCII(char)
返回字符的ASCII码值BIT_LENGTH(str)
返回字符串的比特长度CONCAT(s1,s2...,sn)
将s1,s2...,sn连接成字符串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中所有字符改变为小写后的结果LEFT(str,x)
返回字符串str中最左边的x个字符LENGTH(s)
返回字符串str中的字符数LTRIM(str)
从字符串str中切掉开头的空格POSITION(substr,str)
返回子串substr在字符串str中第一次出现的位置QUOTE(str)
用反斜杠转义str中的单引号REPEAT(str,srchstr,rplcstr)
返回字符串str重复x次的结果REVERSE(str)
返回颠倒字符串str的结果RIGHT(str,x)
返回字符串str中最右边的x个字符RTRIM(str)
返回字符串str尾部的空格STRCMP(s1,s2)
比较字符串s1和s2TRIM(str)
去除字符串首部和尾部的所有空格UCASE(str)
或UPPER(str)
返回将字符串str中所有字符转变为大写后的结果
四、日期和时间函数
CURDATE()
或CURRENT_DATE()
返回当前的日期CURTIME()
或CURRENT_TIME()
返回当前的时间DATE_ADD(date,INTERVAL int keyword)
返回日期date加上间隔时间int的结果(int必须按照关键字进行格式化),如:SELECTDATE_ADD(CURRENT_DATE,INTERVAL 6 MONTH);
DATE_FORMAT(date,fmt)
依照指定的fmt格式格式化日期date值DATE_SUB(date,INTERVAL int keyword)
返回日期date加上间隔时间int的结果(int必须按照关键字进行格式化),如:SELECTDATE_SUB(CURRENT_DATE,INTERVAL 6 MONTH);
DAYOFWEEK(date)
返回date所代表的一星期中的第几天(1~7)DAYOFMONTH(date)
返回date是一个月的第几天(1~31)DAYOFYEAR(date)
返回date是一年的第几天(1~366)DAYNAME(date)
返回date的星期名,如:SELECT DAYNAME(CURRENT_DATE);
FROM_UNIXTIME(ts,fmt)
根据指定的fmt格式,格式化UNIX时间戳tsHOUR(time)
返回time的小时值(0~23)MINUTE(time)
返回time的分钟值(0~59)MONTH(date)
返回date的月份值(1~12)MONTHNAME(date)
返回date的月份名,如:SELECT MONTHNAME(CURRENT_DATE);
NOW()
返回当前的日期和时间QUARTER(date)
返回date在一年中的季度(1~4),如SELECT QUARTER(CURRENT_DATE);
WEEK(date)
返回日期date为一年中第几周(0~53)YEAR(date)
返回日期date的年份(1000~9999)
一些示例:
获取当前系统时间:
1
2
3
4
|
SELECT FROM_UNIXTIME(UNIX_TIMESTAMP()); SELECT EXTRACT(YEAR_MONTH FROM CURRENT_DATE ); SELECT EXTRACT(DAY_SECOND FROM CURRENT_DATE ); SELECT EXTRACT(HOUR_MINUTE FROM CURRENT_DATE ); |
返回两个日期值之间的差值(月数):
1
|
SELECT PERIOD_DIFF(200302,199802); |
在mysql中计算年龄:
1
|
SELECT DATE_FORMAT(FROM_DAYS(TO_DAYS(NOW())-TO_DAYS(birthday)), \'%Y\' )+0 AS age FROM employee; |
这样,如果Brithday是未来的年月日的话,计算结果为0。
下面的SQL语句计算员工的绝对年龄,即当Birthday是未来的日期时,将得到负值。
1
|
SELECT DATE_FORMAT(NOW(), \'%Y\' ) - DATE_FORMAT(birthday, \'%Y\' ) -(DATE_FORMAT(NOW(), \'00-%m-%d\' ) <DATE_FORMAT(birthday, \'00-%m-%d\' )) AS age from employee |
五、加密函数
AES_ENCRYPT(str,key)
返回用密钥key对字符串str利用高级加密标准算法加密后的结果,调用AES_ENCRYPT的结果是一个二进制字符串,以BLOB类型存储AES_DECRYPT(str,key)
返回用密钥key对字符串str利用高级加密标准算法解密后的结果DECODE(str,key)
使用key作为密钥解密加密字符串strENCRYPT(str,salt)
使用UNIXcrypt()函数,用关键词salt(一个可以惟一确定口令的字符串,就像钥匙一样)加密字符串strENCODE(str,key)
使用key作为密钥加密字符串str,调用ENCODE()的结果是一个二进制字符串,它以BLOB类型存储MD5()
计算字符串str的MD5校验和PASSWORD(str)
返回字符串str的加密版本,这个加密过程是不可逆转的,和UNIX密码加密过程使用不同的算法。SHA()
计算字符串str的安全散列算法(SHA)校验和
示例:
1
2
3
4
5
6
7
|
SELECT ENCRYPT( \'root\' , \'salt\' ); SELECT ENCODE( \'xufeng\' , \'key\' ); SELECT DECODE(ENCODE( \'xufeng\' , \'key\' ), \'key\' );#加解密放在一起 SELECT AES_ENCRYPT( \'root\' , \'key\' ); SELECT AES_DECRYPT(AES_ENCRYPT( \'root\' , \'key\' ), \'key\' ); SELECT MD5( \'123456\' ); SELECT SHA( \'123456\' ); |
六、控制流函数
MySQL有4个函数是用来进行条件操作的,这些函数可以实现SQL的条件逻辑,允许开发者将一些应用程序业务逻辑转换到数据库后台。
MySQL控制流函数:
CASE WHEN[test1] THEN [result1]...ELSE [default] END
如果testN是真,则返回resultN,否则返回defaultCASE [test] WHEN[val1] THEN [result]...ELSE [default]END
如果test和valN相等,则返回resultN,否则返回defaultIF(test,t,f)
如果test是真,返回t;否则返回fIFNULL(arg1,arg2)
如果arg1不是空,返回arg1,否则返回arg2NULLIF(arg1,arg2)
如果arg1=arg2返回NULL;否则返回arg1
这些函数的第一个是IFNULL()
,它有两个参数,并且对第一个参数进行判断。如果第一个参数不是NULL,函数就会向调用者返回第一个参数;如果是NULL,将返回第二个参数。
如:SELECT IFNULL(1,2), IFNULL(NULL,10),IFNULL(4*NULL,\'false\');
NULLIF()函数将会检验提供的两个参数是否相等,如果相等,则返回NULL,如果不相等,就返回第一个参数。
如:SELECT NULLIF(1,1),NULLIF(\'A\',\'B\'),NULLIF(2+3,4+1);
和许多脚本语言提供的IF()
函数一样,MySQL的IF()函数也可以建立一个简单的条件测试,这个函数有三个参数,第一个是要被判断的表达式,如果表达式为真,IF()将会返回第二个参数,如果为假,IF()将会返回第三个参数。
如:SELECTIF(1<10,2,3),IF(56>100,\'true\',\'false\');
IF()
函数在只有两种可能结果时才适合使用。然而,在现实世界中,我们可能发现在条件测试中会需要多个分支。在这种情况下,MySQL提供了CASE函数,它和php及Perl语言的switch-case
条件例程一样。
CASE函数的格式有些复杂,通常如下所示:
1
2
3
4
5
6
7
8
|
CASE [expression to be evaluated] WHEN [val 1] THEN [result 1] WHEN [val 2] THEN [result 2] WHEN [val 3] THEN [result 3] ...... WHEN [val n] THEN [result n] ELSE [ default result] END |
这里,第一个参数是要被判断的值或表达式,接下来的是一系列的WHEN-THEN
块,每一块的第一个参数指定要比较的值,如果为真,就返回结果。所有的WHEN-THEN块将以ELSE块结束,当END结束了所有外部的CASE块时,如果前面的每一个块都不匹配就会返回ELSE块指定的默认结果。如果没有指定ELSE块,而且所有的WHEN-THEN比较都不是真,MySQL将会返回NULL。
CASE函数还有另外一种句法,有时使用起来非常方便,如下:
1
2
3
4
5
|
CASE WHEN [conditional test 1] THEN [result 1] WHEN [conditional test 2] THEN [result 2] ELSE [ default result] END |
这种条件下,返回的结果取决于相应的条件测试是否为真。
示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
mysql> SELECT CASE \'green\' WHEN \'red\' THEN \'stop\' WHEN \'green\' THEN \'go\' END ; SELECT CASE 9 WHEN 1 THEN \'a\' WHEN 2 THEN \'b\' ELSE \'N/A\' END ; SELECT CASE WHEN (2+2)=4 THEN \'OK\' WHEN (2+2)<>4 THEN \'not OK\' END ASSTATUS; SELECT Name ,IF((IsActive = 1), \'已激活\' , \'未激活\' ) AS RESULT FROMUserLoginInfo; SELECT fname,lname,(math+sci+lit) AS total, CASE WHEN (math+sci+lit) < 50 THEN \'D\' WHEN (math+sci+lit) BETWEEN 50 AND 150 THEN \'C\' WHEN (math+sci+lit) BETWEEN 151 AND 250 THEN \'B\' ELSE \'A\' END AS grade FROM marks; SELECT IF(ENCRYPT( \'sue\' , \'ts\' )=upass, \'allow\' , \'deny\' ) AS LoginResultFROM users WHERE uname = \'sue\' ;#一个登陆验证 |
七、格式化函数
DATE_FORMAT(date,fmt)
依照字符串fmt格式化日期date值FORMAT(x,y)
把x格式化为以逗号隔开的数字序列,y是结果的小数位数INET_ATON(ip)
返回IP地址的数字表示INET_NTOA(num)
返回数字所代表的IP地址TIME_FORMAT(time,fmt)
依照字符串fmt格式化时间time值
其中最简单的是FORMAT()
函数,它可以把大的数值格式化为以逗号间隔的易读的序列。
示例:
1
2
3
4
5
6
7
|
SELECT FORMAT(34234.34323432,3); SELECT DATE_FORMAT(NOW(), \'%W,%D %M %Y %r\' ); SELECT DATE_FORMAT(NOW(), \'%Y-%m-%d\' ); SELECT DATE_FORMAT(19990330, \'%Y-%m-%d\' ); SELECT DATE_FORMAT(NOW(), \'%h:%i %p\' ); SELECT INET_ATON( \'10.122.89.47\' ); SELECT INET_NTOA(175790383); |
八、类型转化函数
为了进行数据类型转化,MySQL提供了CAST()
函数,它可以把一个值转化为指定的数据类型。类型有:BINARY
,CHAR
,DATE
,TIME
,DATETIME
,SIGNED
,UNSIGNED
示例:
1
2
|
SELECT CAST (NOW() AS SIGNED INTEGER ),CURDATE()+0; SELECT \'f\' = BINARY \'F\' , \'f\' = CAST ( \'F\' AS BINARY ); |
九、系统信息函数
DATABASE()
返回当前数据库名BENCHMARK(count,expr)
将表达式expr重复运行count次CONNECTION_ID()
返回当前客户的连接IDFOUND_ROWS()
返回最后一个SELECT查询进行检索的总行数USER()或SYSTEM_USER()
返回当前登陆用户名VERSION()
返回MySQL服务器的版本
示例:
1
2
|
SELECT DATABASE (),VERSION(), USER (); SELECTBENCHMARK(9999999,LOG(RAND()*PI()));#该例中,MySQL计算LOG(RAND()*PI())表达式9999999次。 |
MySQL数据库提供了很多函数包括:
- 数学函数;
- 字符串函数;
- 日期和时间函数;
- 条件判断函数;
- 系统信息函数;
- 加密函数;
- 格式化函数;
一、数学函数
数学函数主要用于处理数字,包括整型、浮点数等。
函数 | 作用 |
ABS(x) |
返回x的绝对值 SELECT ABS(-1) -- 返回1 |
CEIL(x),CEILING(x) |
返回大于或等于x的最小整数 SELECT CEIL(1.5) -- 返回2 |
FLOOR(x) |
返回小于或等于x的最大整数 SELECT FLOOR(1.5) -- 返回1 |
RAND() |
返回0->1的随机数 SELECT RAND() --0.93099315644334 |
RAND(x) |
返回0->1的随机数,x值相同时返回的随机数相同 SELECT RAND(2) --1.5865798029924 |
SIGN(x) |
返回x的符号,x是负数、0、正数分别返回-1、0和1 SELECT SIGN(-10) -- (-1) |
PI() |
返回圆周率(3.141593) SELECT PI() --3.141593 |
TRUNCATE(x,y) |
返回数值x保留到小数点后y位的值(与ROUND最大的区别是不会进行四舍五入) SELECT TRUNCATE(1.23456,3) -- 1.234 |
ROUND(x) | 返回离x最近的整数 SELECT ROUND(1.23456) --1 |
ROUND(x,y) |
保留x小数点后y位的值,但截断时要进行四舍五入 SELECT ROUND(1.23456,3) -- 1.235 |
POW(x,y).POWER(x,y) |
返回x的y次方 SELECT POW(2,3) -- 8 |
SQRT(x) |
返回x的平方根 SELECT SQRT(25) -- 5 |
EXP(x) |
返回e的x次方 SELECT EXP(3) -- 20.085536923188 |
MOD(x,y) |
返回x除以y以后的余数 SELECT MOD(5,2) -- 1 |
LOG(x) |
返回自然对数(以e为底的对数) SELECT LOG(20.085536923188) -- 3 |
LOG10(x) |
返回以10为底的对数 SELECT LOG10(100) -- 2 |
RADIANS(x) |
将角度转换为弧度 SELECT RADIANS(180) -- 3.1415926535898 |
DEGREES(x) |
将弧度转换为角度 SELECT DEGREES(3.1415926535898) -- 180 |
SIN(x) |
求正弦值(参数是弧度) SELECT SIN(RADIANS(30)) -- 0.5 |
ASIN(x) | 求反正弦值(参数是弧度) |
COS(x) | 求余弦值(参数是弧度) |
ACOS(x) | 求反余弦值(参数是弧度) |
TAN(x) | 求正切值(参数是弧度) |
ATAN(x) ATAN2(x) | 求反正切值(参数是弧度) |
COT(x) | 求余切值(参数是弧度) |
二、字符串函数
字符串函数是MySQL中最常用的一类函数,字符串函数主要用于处理表中的字符串。
函数 | 说明 |
CHAR_LENGTH(s) |
返回字符串s的字符数 SELECT CHAR_LENGTH(\'你好123\') -- 5 |
LENGTH(s) |
返回字符串s的长度 SELECT LENGTH(\'你好123\') -- 9 |
CONCAT(s1,s2,...) |
将字符串s1,s2等多个字符串合并为一个字符串 SELECT CONCAT(\'12\',\'34\') -- 1234 |
CONCAT_WS(x,s1,s2,...) |
同CONCAT(s1,s2,...)函数,但是每个字符串直接要加上x SELECT CONCAT_WS(\'@\',\'12\',\'34\') -- 12@34 |
INSERT(s1,x,len,s2) |
将字符串s2替换s1的x位置开始长度为len的字符串 SELECT INSERT(\'12345\',1,3,\'abc\') -- abc45 |
UPPER(s),UCAASE(S) |
将字符串s的所有字母变成大写字母 SELECT UPPER(\'abc\') -- ABC |
LOWER(s),LCASE(s) |
将字符串s的所有字母变成小写字母 SELECT LOWER(\'ABC\') -- abc |
LEFT(s,n) |
返回字符串s的前n个字符 SELECT LEFT(\'abcde\',2) -- ab |
RIGHT(s,n) |
返回字符串s的后n个字符 SELECT RIGHT(\'abcde\',2) -- de |
LPAD(s1,len,s2) |
字符串s2来填充s1的开始处,使字符串长度达到len SELECT LPAD(\'abc\',5,\'xx\') -- xxabc |
RPAD(s1,len,s2) |
字符串s2来填充s1的结尾处,使字符串的长度达到len SELECT RPAD(\'abc\',5,\'xx\') -- abcxx |
LTRIM(s) | 去掉字符串s开始处的空格 |
RTRIM(s) | 去掉字符串s结尾处的空格 |
TRIM(s) | 去掉字符串s开始和结尾处的空格 |
TRIM(s1 FROM s) |
去掉字符串s中开始处和结尾处的字符串s1 SELECT TRIM(\'@\' FROM \'@@abc@@\') -- abc |
REPEAT(s,n) |
将字符串s重复n次 SELECT REPEAT(\'ab\',3) -- ababab |
SPACE(n) | 返回n个空格 |
REPLACE(s,s1,s2) |
将字符串s2替代字符串s中的字符串s1 SELECT REPLACE(\'abc\',\'a\',\'x\') --xbc |
STRCMP(s1,s2) | 比较字符串s1和s2 |
SUBSTRING(s,n,len) | 获取从字符串s中的第n个位置开始长度为len的字符串 |
MID(s,n,len) | 同SUBSTRING(s,n,len) |
LOCATE(s1,s),POSITION(s1 IN s) |
从字符串s中获取s1的开始位置 SELECT LOCATE(\'b\', \'abc\') -- 2 |
INSTR(s,s1) |
从字符串s中获取s1的开始位置 SELECT INSTR(\'abc\',\'b\') -- 2 |
REVERSE(s) |
将字符串s的顺序反过来 SELECT REVERSE(\'abc\') -- cba |
ELT(n,s1,s2,...) |
返回第n个字符串 SELECT ELT(2,\'a\',\'b\',\'c\') -- b |
EXPORT_SET(x,s1,s2) |
返回一个字符串,在这里对于在“bits”中设定每一位,你得到一个“on”字符串,并且对于每个复位(reset)的位,你得到一个 “off”字符串。每个字符串用“separator”分隔(缺省“,”),并且只有“bits”的“number_of_bits” (缺省64)位被使用。 SELECT EXPORT_SET(5,\'Y\',\'N\',\',\',4) -- Y,N,Y,N |
FIELD(s,s1,s2...) |
返回第一个与字符串s匹配的字符串位置 SELECT FIELD(\'c\',\'a\',\'b\',\'c\') -- 3 |
FIND_IN_SET(s1,s2) | 返回在字符串s2中与s1匹配的字符串的位置 |
MAKE_SET(x,s1,s2) | 返回一个集合 (包含由“,”
字符分隔的子串组成的一个 字符串),由相应的位在 SELECT MAKE_SET(1|4,\'a\',\'b\',\'c\'); -- a,c |
SUBSTRING_INDEX |
返回从字符串str的第count个出现的分隔符delim之后的子串。 如果count是正数,返回第count个字符左边的字符串。 如果count是负数,返回第(count的绝对值(从右边数))个字符右边的字符串。 SELECT SUBSTRING_INDEX(\'a*b\',\'*\',1) -- a |
LOAD_FILE(file_name) |
读入文件并且作为一个字符串返回文件内容。文件必须在服务器上,你必须指定到文件的完整路径名,而且你必须有file权 限。文件必须所有内容都是可读的并且小于max_allowed_packet。 如果文件不存在或由于上面原因之一不能被读出,函数返回NULL。 |
三、日期时间函数
MySQL的日期和时间函数主要用于处理日期时间。
函数 | 说明 |
CURDATE(),CURRENT_DATE() |
返回当前日期 SELECT CURDATE() |
CURTIME(),CURRENT_TIME |
返回当前时间 SELECT CURTIME() |
NOW(),CURRENT_TIMESTAMP(),LOCALTIME(), SYSDATE(),LOCALTIMESTAMP() |
返回当前日期和时间 SELECT NOW() |
UNIX_TIMESTAMP() |
以UNIX时间戳的形式返回当前时间 SELECT UNIX_TIMESTAMP() |
UNIX_TIMESTAMP(d) |
将时间d以UNIX时间戳的形式返回 SELECT UNIX_TIMESTAMP(\'2011-11-11 11:11:11\') |
FROM_UNIXTIME(d) |
将UNIX时间戳的时间转换为普通格式的时间 SELECT FROM_UNIXTIME(1320981071) |
UTC_DATE() |
返回UTC日期 SELECT UTC_DATE() |
UTC_TIME() |
返回UTC时间 SELECT UTC_TIME() |
MONTH(d) |
返回日期d中的月份值,1->12 SELECT MONTH(\'2011-11-11 11:11:11\') |
MONTHNAME(d) |
返回日期当中的月份名称,如Janyary SELECT MONTHNAME(\'2011-11-11 11:11:11\') |
DAYNAME(d) |
返回日期d是星期几,如Monday,Tuesday SELECT DAYNAME(\'2011-11-11 11:11:11\') |
DAYOFWEEK(d) |
日期d今天是星期几,1星期日,2星期一 SELECT DAYOFWEEK(\'2011-11-11 11:11:11\') |
WEEKDAY(d) |
日期d今天是星期几, 0表示星期一,1表示星期二 |
WEEK(d),WEEKOFYEAR(d) |
计算日期d是本年的第几个星期,范围是0->53 SELECT WEEK(\'2011-11-11 11:11:11\') |
DAYOFYEAR(d) |
计算日期d是本年的第几天 SELECT DAYOFYEAR(\'2011-11-11 11:11:11\') |
DAYOFMONTH(d) |
计算日期d是本月的第几天 SELECT DAYOFMONTH(\'2011-11-11 11:11:11\') |
QUARTER(d) |
返回日期d是第几季节,返回1->4 SELECT QUARTER(\'2011-11-11 11:11:11\') |
HOUR(t) |
返回t中的小时值 SELECT HOUR(\'1:2:3\') |
MINUTE(t) |
返回t中的分钟值 SELECT MINUTE(\'1:2:3\') |
SECOND(t) |
返回t中的秒钟值 SELECT SECOND(\'1:2:3\') |
EXTRACT(type FROM d) |
从日期d中获取指定的值,type指定返回的值 SELECT EXTRACT(MINUTE FROM \'2011-11-11 11:11:11\') type可取值为: MICROSECOND |
TIME_TO_SEC(t) |
将时间t转换为秒 SELECT TIME_TO_SEC(\'1:12:00\') |
SEC_TO_TIME(s) |
将以秒为单位的时间s转换为时分秒的格式 SELECT SEC_TO_TIME(4320) |
TO_DAYS(d) |
计算日期d距离0000年1月1日的天数 SELECT TO_DAYS(\'0001-01-01 01:01:01\') |
FROM_DAYS(n) |
计算从0000年1月1日开始n天后的日期 SELECT FROM_DAYS(1111) |
DATEDIFF(d1,d2) |
计算日期d1->d2之间相隔的天数 SELECT DATEDIFF(\'2001-01-01\',\'2001-02-02\') |
ADDDATE(d,n) |
计算其实日期d加上n天的日期 |
ADDDATE(d,INTERVAL expr type) |
计算起始日期d加上一个时间段后的日期 SELECT ADDDATE(\'2011-11-11 11:11:11\',1) SELECT ADDDATE(\'2011-11-11 11:11:11\', INTERVAL 5 MINUTE) |
DATE_ADD(d,INTERVAL expr type) | 同上 |
SUBDATE(d,n) |
日期d减去n天后的日期 SELECT SUBDATE(\'2011-11-11 11:11:11\', 1) |
SUBDATE(d,INTERVAL expr type) |
日期d减去一个时间段后的日期 SELECT SUBDATE(\'2011-11-11 11:11:11\', INTERVAL 5 MINUTE) |
ADDTIME(t,n) |
时间t加上n秒的时间 SELECT ADDTIME(\'2011-11-11 11:11:11\', 5) |
SUBTIME(t,n) |
时间t减去n秒的时间 SELECT SUBTIME(\'2011-11-11 11:11:11\', 5) |
DATE_FORMAT(d,f) |
按表达式f的要求显示日期d SELECT DATE_FORMAT(\'2011-11-11 11:11:11\',\'%Y-%m-%d %r\') |
TIME_FORMAT(t,f) |
按表达式f的要求显示时间t SELECT TIME_FORMAT(\'11:11:11\',\'%r\') |
GET_FORMAT(type,s) |
获得国家地区时间格式函数 select get_format(date,\'usa\') |
四、条件判断函数
1、IF(expr,v1,v2)函数
如果表达式expr成立,返回结果v1;否则,返回结果v2。
SELECT IF(1 > 0,\'正确\',\'错误\') ->正确
2、IFNULL(v1,v2)函数
如果v1的值不为NULL,则返回v1,否则返回v2。
SELECT IFNULL(null,\'Hello Word\') ->Hello Word
3、CASE
语法1:
CASE WHEN e1 THEN v1 WHEN e2 THEN e2 ... ELSE vn MySQL学习笔记——计算字段及常用函数