MySQL函数

一、引入

函数指的是可以直接被调用的一段代码,就是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个长度的字符串

注意:

lpadrpad中的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
2
3
date_add(now(), interval 10 day); // 当前时间加上10
date_add(now(), interval 10 year); // 当前时间加上10
// second minute hour day month year 秒 分 时 天 月 年

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;