一.函数
1.数学函数
CEIL()进一取整
SELECT CEIL(1.2);2
FLOOR()舍一取整
SELECT FLOOR(1.9);9
MOD取余数(取模)
SELECT MOD(3,8);3--3对8取模
POWER()幂运算
SELECT POWER(3,2);9
ROUND()四舍五入
SELECT ROUND(123.456,2);123.46
TRUNCTATE数字截取
SELECT TRUNCATE(123.456,2);123.45
ABS()取绝对值
SELECT ABS(-123);123
PI()圆周率
SELECT PI();3.14
RAND()和RAND(X)
SELECT RAND();0到1之间的一个随机数
SELECT RAND(2);0到1之间的一个随机数
ORDER BY RAND();按随机排序
SIGN(X)得到数值符合正数0和负数1
EXP(X)e的X方
2.字符串函数
LENGTH返回字符串长度
SELECT LENGTH('KAIKEBA');7
SELECT LENGTH('开课吧');6
CHAR_LENGTH返回字符串的字符数
SELECT CHAR_LENGTH('KAIKEBA');7
SELECT CHAR_LENGTH('开课吧');3
CONCAT(S1,S2,……)将字符串连接到一起
SELECT CONCAT('S','S','M');SSM
SELECT CONCAT('S',' ','M');SM
SELECT CONCAT('S','S',NULL);NULL字符串中有NULL,结果为NULL.
CONCAT_WS(S1,S2,……)以指定的分隔符将字符串连接到一起
SELECT CONCAT_WS('#','S','w','M');S#w#M
SELECTCONCAT_WS('#','S','w','M',NULL);S#w#M
SELECT CONCAT_WS(NULL,'S','w','M');NULL
UPPER(S)/UCASE(S)将字符串中的小写变大写
SELECTUPPER('RanDongmei'),UCASE('RanDongmei');RANDONGMEI RANDONGMEI
LOWER(s)/LCASE(S)将字符串中的大写变小写
LEFT(S,N)/RIGHT(S,N)返回字符串S前N个字符,后N个字符
SELECT LEFT('kaikeba',3);kai
SELECT RIGHT('天天向上,加油',2);油
LPAD|RPAD使用指定字符左填充或右填充至规定字符数
SELECT LPAD('KAI',5,'!');!!KAI
SELECT RPAD('KAI',5,'!');KAI!!
LTRIM|RTRIM|TRIM去掉字符串左边|右边|两边的空格
SELECT ' abc';
SELECT CONCAT('+',' AVC ','+');+ AVC +
SELECT CONCAT('+',LTRIM(' AVC '),'+');+AVC+
SELECT CONCAT('+',RTRIM(' AVC '),'+');+AVC+
SELECT CONCAT('+',TRIM(' AVC '),'+');+AVC+
只有TRIM采有下面两种形式,LTRIM与RTRIM没有
SELECT TRIM('ABCBA'FROM 'A');A
SELECT TRIM('A'FROM 'ABCNA');BCN
SELECT TRIM('A'FROM 'ABCANA');BCAN
REPEAT(S,N)将字符串S重复N次
SELECT REPEAT('A',10);AAAAAAAAAA
SPACE(N)填充N个空格
SELECT SPACE(5);
SELECT CONCAT('+',SPACE(5),'+');+ +
REPLACE(S,S1,S2);将字符串S中的S1替换为S2
SELECTREPLACE('AAAASDDFO','A','R');RRRRSDDFO
STRCMP(S1,S2);比较字符串S1和S2,若相等返回0,若S1>S2返回1,若S1
SELECT STRCMP('A','A');0
SELECT STRCMP('A','B');-1
SELECT STRCMP('B','A');1第一个字符串大于第二个字符串
SELECT STRCMP('A','a');0不区分大小写
SUBSTRINT(S,a,b)从字符串的第a个字符取到第b个字符
SELECT SUBSTRING('KAIKEBA',1,3);KAI
从1开始,截取三个字符
SELECT SUBSTRING('KAIKEBA',-2,3);BA
SELECT SUBSTRING('KAIKEBA',-2,1);B
REVERSE(S);反转字符串S
SELECT REVERSE('ABCDE');EDCBA
ELT(N,S1,S2,S3,……);返回指定位置的字符串
SELECT ELT(3,'a','b','c','d');c
3.日期时间函数
返回当前日期
SELECT CURDATE();
SELECT CURRENT_DATE();
返回当前时间
SELECT CURTIME();
SELECT CURRENT_TIME();
返回当前日期时间
SELECT NOW();2014-11-07
SELECT SYSDATE();
返回月份
SELECT MONTH('2014-12-16');12
SELECT MONTHNAME(NOW());NOVEMBER
返回星期几
SELECT DAYNAME(NOW());Friday
一周的第几天,1:星期日
SELECT DAYOFWEEK(NOW());6
返回日期是星期几,0代表星期一
SELECT WEEKDAY(NOW());4
SELECT WEEK(NOW());44一年中的第44个星期
SELECT YEAR(NOW());2014
SELECT HOUR(NOW());
SELECT MINUTE(NOW());
SELECT SECOND(NOW());
计算两个日期间相隔天数
SELECTDATEDIFF('1988-12-16','2014-11-07');-9457天
SELECTDATEDIFF('1964-04-16','2014-11-07');-18467天
4.系统函数
SELECT VERSION();当前数据库版本号
SELECT CONNECTION_ID();当前服务器的连接数
当前数据库:
SELECT DATABASE();
SELECT SCHEMA();
当前用户
SELECT USER();
SELECT SYSTEM_USER();
SELECT CURRENT_USER();
SELECT CURRENT_USER;
返回字符串STR的字符集
SELECT CHARSET('AFA');
SELECT LAST_INSERT_ID();最后一条插入记录ID号
5.加密函数
MD5()
PASSWORD();
SELECT MD5('ROOT');
SELECT PASSWORD('ROOT');
PASSWORD针对用户密码加密
SELECT * FROM user