mysql常用内置函数

MySQL提供的内置函数从实现的功能角度可以分为数值函数字符串函数日期和时间函数流程控制函数加密与解密函数获取MySQL信息函数聚合函数

这里,我将这些丰富的内置函数再分为两类: 单行函数 聚合函数(或分组函数)。

1.数值函数

1.1基本函数

函数 用法
abs(x) 取绝对值
sign(x) 返回x的符号。正数返回1,负数返回-1,0返回0
pi() 返回圆周率的值
ceil(x),ceiling(x) 返回大于或等于某个值的最小整数
floor(x) 返回小于或等于某个值的最大整数
least(e1,e2,e3…) 返回多个参数的最小值
greatest(e1,e2,e3…) 返回多个参数的最大值
mod(a,b) a%b的值
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

1.2角度和弧度互函数

函数 用法
radians(x) 将角度转化为弧度,其中,参数x为角度值
degrees(x) 将弧度转化为角度,其中,参数x为弧度值

1.3三角函数

函数 功能
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为弧度值

1.4指数和对数

函数 用法
pow(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

1.5进制间的转换

2.字符串函数

函数 用法
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,...)函数,但是每个字符串之间要加上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中首次出现的位置,作用于POSITION(substr IN str)、INSTR(str,substr)相同。未找到,返回0
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

注意:MySQL中,字符串的位置是从1开始的。

3.日期和时间函数

3.1获取日期、时间

函数 用法
CURDATE() ,CURRENT_DATE() 返回当前日期,只包含年、 月、日
CURTIME() , CURRENT_TIME() 返回当前时间,只包含时、 分、秒
NOW() / SYSDATE() / CURRENT_TIMESTAMP() / LOCALTIME() / LOCALTIMESTAMP() 返回当前系统日期和时间
UTC_DATE() 返回UTC(世界标准时间) 日期
UTC_TIME() 返回UTC(世界标准时间) 时间

3.2 日期与时间戳的转换

3.3 获取月份、星期、星期数、天数等函数

3.4 日期的操作函数

该函数的type的取值与含义为:

mysql常用内置函数_第1张图片

 

3.5 时间和秒钟转换的函数

3.6 计算日期和时间的函数

  • str_to_date:将字符串按格式解析转为日期格式
    • SELECT STR_TO_DATE("21-04-2001","%d-%m-%Y")返回2001-04-21
  • date_format:将日期格式化为字符串
    • SELECT date_format("2001/04/21","%Y年%m月%d日")返回2001年04月21日
  • datediff:显示两个日期的差值,天数
    • SELECT  datediff(now(),"2001-04-21")返回7589

mysql常用内置函数_第2张图片

其它函数

  • version:当前版本
  • database:当前数据库
  • user:当前版本
  • password:加密
  • MD5:md5加密

流程控制函数

  • if:第一个参数是表达式,第二个参数是条件为true执行的,第三个fasle执行的
    • SELECT if(6<3,"ok","no ok")返回no ok
  • case

①类似switch case的用法

case 要判断的字段或表达式

when 常量1 then 要执行的语句或返回值

when 常量2 then 要执行的语句或返回值

else要执行的语句或返回值

end

例子:

use employee;
SELECT name,
case SUBSTR(name,1,1)
when "李" then "李世民"
when "王" then "王老五"
else "无名氏"
end 
as 昵称
from employeement

②类似if else if……else的用法

case 

when 条件1 then 要执行的语句或返回值

when 条件1 then 要执行的语句或返回值

else 要执行的语句或返回值

end

分组函数

  • sum:求和,忽略null值
  • avg:平均值,忽略null值
  • max、min:最大值最小值
  • count:计算非空个数

可以配合distinct,如SELECT  sum(distinct age),sum(age) from employeement;两个返回值不同

你可能感兴趣的:(mysql,mysql,数据库,database)