文章目录
🌈 一、日期函数
⭐ 1. 常见日期函数
函数 | 说明 |
---|---|
curdate() | 获取当前日期(年月日) |
curtime() | 获取当前时间(时分秒) |
now() | 获取当期日期和时间 |
year(datetime) | 返回 datetime 参数中的年份部分 |
month(datetime) | 返回 datetime 参数中的月份部分 |
day(datetime) | 返回 datetime 参数中的天数部分 |
date(datetime) | 获取 datetime 参数中的日期部分 |
time(datetime) | 获取 datetime 参数中的时间部分 |
date_add(date, interval expr type) | 在 date 中添加日期或时间,expr 的数值单位 type 可以是:year、month、day、hour、minute、second |
date_sub(datetime, interval expr type) | 在 datetime 中减去日期或时间,expr 的数值单位 type 可以是:year、month、day、hour、minute、second |
datediff(date1, date2) | 获取两个日期之间相差的天数 (date1 - date2) |
⭐ 2. 日期函数使用示例
01. curdate 函数
- 用于获取当前的日期:
02. curtime 函数
- 获取当前的时间 (24h 制):
03. now 函数
- 获取当前的日期和时间。
04. year 函数
- 获取所给定参数中的年份部分。
- 也支持将其他函数的返回值作为函数参数,如:将 curdate() 的返回值作为 year 函数的参数。
05. month 函数
- 获取所给定的时间参数中的月份部分
- 该函数同样支持以其他函数的返回值作为参数。
06. day 函数
- 返回所给定的时间参数中的天数部分。
07. date 函数
- 返回所给定的时间参数中的日期部分。
08. time 函数
- 返回所给定的时间参数中的时间部分。
09. date_add 函数
- 在指定日期或时间的基础上添加日期或时间。
- 如果给定的 expr 值是个负数 ,则相当于在日期的基础上减去日期 / 时间。
**10. date_add **
- 在指定日期或时间的基础上减去日期或时间。
- 如果给定的 expr 值是个负数,则相当于在日期的基础上加上日期 / 时间。
11. datediff 函数
- 获取两个日期之间相差的天数。
- 该函数是用第一个参数的时间减去第二个参数的时间。
⭐ 3. 日期函数综合案例
1. 生日表
- 创建一张名为 tmp 的生日表用来记录生日,表中包含一个主键自增的 id 字段,以及一个 date 类型的 birthday 字段。
- 往表中的 birthday 字段插入当前日期作为生日。
2. 留言表
- 创建一张名为 msg 的留言表,表中包含自增长的主键 id、留言人姓名 name、评论内容 content、以及评论时间 sendtim 这 4 个字段。
- 不定时的往表中插入数据,可用 now 函数指定评论时间。
- 显示所有留言信息,可使用 date 函数让发布日期只显示日期,不用显示时间
- 查询在 3 分钟之内发布的留言,只需要借助 date_add 和 now 函数筛选出评论时间 sendtime 加上 3 分钟大于当前时间的评论即可。
🌈 二、字符串函数
⭐ 1. 常见字符串函数
函数 | 说明 |
---|---|
charset(str) | 获取指定字符串所使用的字符集 |
concat(str1, str2, …, strn) | 字符串拼接,将 str1, str2, …, strn 拼接成一个字符串 |
instr(str, substr) | 获取 substr 首次在 str 中首次出现的位置,没有出现则返回 0 |
upper(str)、lower(str) | upper 将字符串 str 中的字母全部转为大写,lower 则是转成小写。 |
left(str, length) | 从字符串的最左边开始,向后截取 length 个字符,如果字符串长度小于 length,则截取整个字符串 |
length(str) | 获取指定的字符串所占用的字节数 |
replace(str, search_str, replace_str) | 替换字符串,使用 replace_str 替换掉 search_str |
strcmp(str1, str2) | 字符串比较,逐字符按照 ASCII 码比较两个字符串 |
substring(str, start [, len]) | 返回从字符串 str 的 start 位置开始的 len 个字符的子串,不指定 len 则返回从 start 开始的所有字符 |
ltrim(str)、rtrim(str)、trim(str) | 去掉字符串的头部空格、尾部空格、以及头部和尾部的空格 |
⭐ 2. 字符串函数使用示例
01. charset 函数
- 准备工作:准备一张带有字符串类型字段的成绩表。
- 使用 charset 函数获取 name 字段所使用的字符集。
02. concat 函数
- 对学生表中每名同学的信息以如下格式打印:
- XXX 同学的语文成绩是 XX 分,数学成绩是 XX 分,英语成绩是 XX 分
03. instr 函数
- 获取字符串 ‘world!’ 在 ‘hello world!’ 字符串中首次出现的位置。
04. upper 函数和 lower 函数
- upper 函数用于将指定字符串中的内容全部换成大写。
- lower 函数用于将指定字符串中的内容全部换成小写。
05. left 函数
- 从字符串的第一个字符开始,向后截取指定 length 个字符。
- 如果 length 超过了字符串的长度,则截取整个字符串。
06. length 函数
- 获取指定字符串所占用的字节数。
- 在不同的编码格式中,一个字节所占空间大小是有区别的,如:utf8 下一个字符占 3 字节,而 gbk 下一个字符占 2 字节。
07. replace 函数
- 将字符串中的指定子串替换成另一个字符串,只是字符串级别的替换,并不会变更表中原有的数据。
- 例:将张三的三替换成角。
08. strcmp 函数
- 使用起来和 C 语言的 strcmp 函数一致,就是逐字符按照 ASCII 码比较两个字符串,两个串相等则返回 0,串1 > 串2 则返回 1,串2 > 串1 则返回 -1.
09. substring 函数
- 返回从起始位置开始的 len 个字符。
- 不指定 len 的话则默认返回从 start 开始的所有字符。
10. ltrim、rtrim、trim
- ltrim 函数:去掉字符串左边的空格。
- rtrim 函数:去掉字符串右边的空格。
- trim 函数:去掉字符串左右两边的空格。
⭐ 3. 字符串函数综合案例
- 当前有一张名为 emp 的员工表。
以首字母小写的方式显示员工表中所有员工的姓名
- 使用 substring 函数,截取员工姓名的第一个字符,然后使用 lower 函数将其转换成小写字母。
- 使用 substring 函数,截取员工姓名从第二个开始的所有字符。
- 使用 concat 函数,将前两次截取出来的字符串进行拼接,即可获得首字母小写的员工姓名了。
🌈 三、数值函数
⭐ 1. 常见数值函数
函数 | 说明 |
---|---|
abs(x) | 求绝对值 |
bin(x) | 将十进制的参数转换成二进制显示 |
hex(x) | 将十进制的参数转换成十六进制显示 |
conv(x, from_base, to_base) | 将 x 从 from_base 进制转换成 to_base 进制 |
ceil(x) | 向上取整 |
floor(x) | 向下取整 |
format(x, y) | 求参数 x 的四舍五入后的值,保留 y 位小数 |
rand() | 返回一个 0 ~ 1 之间的随机数 |
mod(x, y) | 返回 x % y 的值 |
⭐ 2. 数值函数使用示例
01. abs 函数
- 获取一个数的绝对值。
02. bin 函数
- 建一个十进制整数转换成二进制。
03. hex 函数
- 将一个十进制整数转换成十六进制。
04. conv 函数
- 将一个数从一个进制转换成另一个进制。
05. ceil 函数
- 对一个数进行向上取整。
- 向上取整本质是向正无穷方向取整,负数向上取整之后得到的是第一个大于等于该数的值。
06. floor 函数
- 对一个整数进行向下取整。
- 向下取整本质是向负无穷方向取整,负数向上取整之后得到的是第一个小于等于该数的值。
07. format 函数
- 对数值进行格式化,以四舍五入的形式保留指定的小数点后的数字。
08. rand 函数
- 生成一个 0 ~ 1 之间的随机浮点数。
- 如果想生成的是 0 ~ n 之间的随机数,可以让 rand() 函数生成的随机数与 n 相乘,在对相乘后的结果取整即可。
- 例:生成一个 0 ~ 10 之间的随机数。
09. mod 函数
- 没啥可说的,就是求 参数1 % 参数2 后的值而已。
🌈 四、流程函数
⭐ 1. 常见流程函数
函数 | 说明 |
---|---|
if(value, t, f) | 如果 value 为 true,则返回 t,否则返回 f |
ifnull(value1, vaule2) | 如果 value1 不为空,则返回 value1,否则返回 value2 |
⭐ 2. 流程函数使用示例
01. if 函数
- 如果参数 1 的值为 true,则返回参数 2,否则返回参数 3。
02. ifnull 函数
- 如果参数 1 不为空,则返回参数 1,否则返回参数 2。