mySQL中的函数

不同数据库中的函数不同的

函数分类

MySQL提供的内置函数从实现的功能角度可以分为数值函数字符串函数日期和时间函数流程控制函数加密与解密函数获取MSQL信息函数聚合函数等。这里,我将这些丰富的内置函数再分为两类:单行函数聚合函数(或分组函数)。

单行函数

数值函数

函数用法
ABS(x)返回x的绝对值
SIGN(X)返回X的符号。正数返回1,负数返回-1,0返回0
PI()返回圆周率的值
CEL(x), CEILING(x)返回某个值的最小整数
FLOOR(x)返回小于或等于某个值的最大正数
LEAST(e1,e2,e3…)返回列表中的最小值
GREATEST(e1,e2,e3…)返回列表中的最大值
MOD(x,y)返回X除以Y后的余数
RAND()返回0~1的随机值
RAND(x)返回0~1的随机值,其中x的值用作种子值,相同的X值会产生相同的随机数
ROUND(x)返回一个对x的值进行四舍五入后,最接近于的整数
ROUND(x,y)返回一个对x的值进行四舍五入后最接近的值,并保留到小数点后面位
TRUNCATE(x,y)返回数字x截断为y位小数的结果
SQRT(x)返回x的平方根。当X的值为负数时,返回NULL

字符串函数

函数用法
ASCII(S)返回字符串S中的第一个字符的ASCI码值
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个字符

时间函数

函数用法
DATE_FORMAT(date,fmt)按照字符串fmt格式化日期date值
TIME_FORMAT(time,fmt)按照字符串fmt格式化日期time值
GET_FORAMT(date_type,format_type)返回日期字符串的显示格式
STR_TO_DATE(str,fmt)按照一个字符串fmt对str进行解析,解析为一个日期

上述 非GET_FORAMT 函数中fmt参数常用的格式符:

格式符说明格式符说明
%Y4为数字表示年份%y2位数字表示年份
%M月名表示月份(January…)%m2位数字表示月份(01,02,03,…)
%b缩写的月名(Jan,…)%c表示月份(1,2,3,…)
%D英文后缀表示月中的天数(1st,2nd,3rd,… )两位数字表示月中的天数01,02,03,…
%e数字形式表示月中的天数(1,2,3,…)
%H两位数字表示小时,24小时制(01,02,03,…)%h和%l;两位数字形式表示小时,12小时制(01,02,…)
%k数字形式的小时,24小时制(1,2,3,…)%l数字形式表示小时,12小时制(01,02,…)
%i两位数字表示分钟(00,01,02,…)%S和%s两位数字表示秒(00,01,02,…)
%W一周中星期的名称(Saturday,…)%a一周中星期的缩写(Sun.,mon.,…)

流程控制函数

函数用法
IF(value,value1,value2)如果value的值为true,返回vualue1,否则返回value2
IF(value1,value2)如果value1不为null,返回vualue1,否则返回value2
CASE WHEN 条件1 THEN 结果1 WHEN 条件2 THEN 结果2 …[ELSE resultn] END相当于if…else if…else…
CASE sxpr WHEN 常量值1 THEN 值1 WHEN 常量值2 THEN 值2…[ELSE 值 n] ENDswitch…case

聚合函数

常见的几个聚合函数

1、AVG(平均值) / SUM(求和) -- 会自动过滤null

select AVG(salary),SUM(salary) from emplayees

2、MAX(最大值) / MIN(最小值) -- 会自动过滤null

select MAX(salary),MIN(salary) from emplayees

3、COUNT

  • 作用:计算指定字段在查询结构中出现的次数
    • 如果计算表中有多少条记录,如何实现?
    • 方式一: COUNT(*)
    • 方式二:COUNT(1)
    • 方式三:COUNT(指定字段) :不一定对 因为计算时会自动排除null
  • 公式: AVG = SUM / COUNT 永远成立

4、GROUP BY

  • 将表中的数据根据字段中的相同值进行若干分组
# 单个字段分组
select dept_id, AVG(salary) from employees GROUP BY dept_id
# 多字段分组
select dept_id, gid AVG(salary) from employees GROUP BY dept_id, gid
  • 结论1:SELECT中出现的非组函数的字段必须声明在GROUP BY中,声明在GROUP BY中的字段可以不出现在SELECT中
  • 结论2 GROUP BY声明在 FROM和WHERE后边,ORDER BY 、LIMIT 前面
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值