MySQL函数
MySQL函数
SmartSage一、引入
函数指的是可以直接被调用的一段代码,就是MySQL已经提供好了一些实用的方法,我们直接调用就可以了。其中在上一篇文章中所讲提到的聚合函数也是函数的一类。
在MySQL中,函数主要分为四类:字符串函数、数值函数、日期函数、流程函数
二、字符串函数
函数 | 功能 |
---|---|
CONCAT(S1,S2,S3…) | 字符串拼接函数 |
LOWER(str) | 将str中的字符全部转换为小写 |
UPPER(str) | 将str中的字符全部转换为大写 |
LPAD(str,n,pad) | 左填充,用字符串pad对str的左边进行填充,达到n个字符串长度 |
RPAD(str,n,pad) | 右填充,用字符串pad对str的右边进行填充,达到n个字符串长度 |
TRIM(str) | 去掉字符串头部和尾部的空格 |
SUBSTRING(str,start,len) | 返回从字符串str从start位置起的len个长度的字符串 |
注意:
lpad
与rpad
中的n,代表的是填充后字符串的长度,pad代表的是用来填充的字符串,例如,pad = 'a'
则会用a填充,如果pad = 'ab'
则会用ab
填充,如果需要填充3个字符就能到达n,则会填充aba
trim
函数只能去掉头部与尾部的空格
substring
函数中,索引值从1开始计算。start参数可以为负数,表示从右开始的第几个字符,比如substring('Hello',-2,5)
是表示从右侧数第二个字符开始截取五个,即结果为lo
三、数值函数
函数 | 功能 |
---|---|
CEIL(x) | 向上取整 |
FLOOR(x) | 向下取整 |
MOD(x,y) | 返回x/y的模 |
RAND() | 返回0-1内的随机数 |
ROUND(x,y) | 求参数x的四舍五入值,保留y为小数 |
四、日期函数
函数 | 功能 |
---|---|
CURDATE() | 返回当前日期 |
CURTIME() | 返回当前时间 |
NOW() | 返回当前日期和时间 |
YEAR(date) | 获取指定date的年份 |
MONTH(date) | 获取指定date的月份 |
DAY(date) | 获取指定date的日期 |
DATE_ADD(date,INTERVAL exprtype) | 但会一个日期/时间值加上一个时间间隔 exprtype后的时间值 |
DATEDIFF(date1,date2) | 返回起始时间date1与结束时间date2之间的天数 |
DATE_ADD举例:
1 | date_add(now(), interval 10 day); // 当前时间加上10天 |
DATEDIFF注意:
返回的是date1 - date2 所以可能会有负数
五、流程函数
流程函数可以在SQL语句中实现条件筛选,从而提高语句的效率。
函数 | 功能 |
---|---|
IF(value, t, f) | 如果value为true,则返回t,否则返回f |
IFNULL(value1, value2) | 如果value1不为空,返回value1,否则返回value2 |
CASE WHEN [val1] THEN [res1] …ELSE [default] END | 如果val1为true,返回res1,…否则返回default默认值 |
CASE [expr] WHEN [val1] THEN [res1] … ELSE [default] END | 如果expr值为val1,返回res1,…否则返回default默认值 |
注意
ifnull
,只会在null情况下才是空,在””情况下不为空。
第三四个函数功能类似。有点类似于switch case
语句
1 | case when val1 then res1 when val2 then res2 else res0 end; |
评论
匿名评论隐私政策
✅ 你无需删除空行,直接评论以获取最佳展示效果