【MySQL 08】内置函数 (带思维导图)

在这里插入图片描述

🌈 一、日期函数

⭐ 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 函数

  • 用于获取当前的日期:

image-20240816092046084

02. curtime 函数

  • 获取当前的时间 (24h 制):

image-20240816092219269

03. now 函数

  • 获取当前的日期和时间。

image-20240816092311820

04. year 函数

  • 获取所给定参数中的年份部分。

image-20240816093019854

  • 也支持将其他函数的返回值作为函数参数,如:将 curdate() 的返回值作为 year 函数的参数。

image-20240816093122128

05. month 函数

  • 获取所给定的时间参数中的月份部分

image-20240816093826105

  • 该函数同样支持以其他函数的返回值作为参数。

image-20240816093914540

06. day 函数

  • 返回所给定的时间参数中的天数部分。

image-20240816094039932

07. date 函数

  • 返回所给定的时间参数中的日期部分。

image-20240816094149499

08. time 函数

  • 返回所给定的时间参数中的时间部分。

image-20240816094411790

09. date_add 函数

  • 在指定日期或时间的基础上添加日期或时间。

image-20240816094851637

  • 如果给定的 expr 值是个负数 ,则相当于在日期的基础上减去日期 / 时间。

image-20240816095500225

**10. date_add **

  • 在指定日期或时间的基础上减去日期或时间。

image-20240816095719671

  • 如果给定的 expr 值是个负数,则相当于在日期的基础上加上日期 / 时间。

image-20240816095831670

11. datediff 函数

  • 获取两个日期之间相差的天数。

image-20240816102135328

  • 该函数是用第一个参数的时间减去第二个参数的时间。

image-20240816102113541

⭐ 3. 日期函数综合案例

1. 生日表

  • 创建一张名为 tmp 的生日表用来记录生日,表中包含一个主键自增的 id 字段,以及一个 date 类型的 birthday 字段。

image-20240816111940168

  • 往表中的 birthday 字段插入当前日期作为生日。

image-20240816112055308

2. 留言表

  • 创建一张名为 msg 的留言表,表中包含自增长的主键 id、留言人姓名 name、评论内容 content、以及评论时间 sendtim 这 4 个字段。

image-20240816112502093

  • 不定时的往表中插入数据,可用 now 函数指定评论时间。

image-20240816113348848

  • 显示所有留言信息,可使用 date 函数让发布日期只显示日期,不用显示时间

image-20240816113408215

  • 查询在 3 分钟之内发布的留言,只需要借助 date_add 和 now 函数筛选出评论时间 sendtime 加上 3 分钟大于当前时间的评论即可。

image-20240816113702482

🌈 二、字符串函数

⭐ 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 函数

  • 准备工作:准备一张带有字符串类型字段的成绩表。

image-20240816155225984

  • 使用 charset 函数获取 name 字段所使用的字符集。

image-20240816155330807

02. concat 函数

  • 对学生表中每名同学的信息以如下格式打印:
    • XXX 同学的语文成绩是 XX 分,数学成绩是 XX 分,英语成绩是 XX 分

image-20240816155922253

03. instr 函数

  • 获取字符串 ‘world!’ 在 ‘hello world!’ 字符串中首次出现的位置。

image-20240816160111938

04. upper 函数和 lower 函数

  • upper 函数用于将指定字符串中的内容全部换成大写。

image-20240816173133113

  • lower 函数用于将指定字符串中的内容全部换成小写。

image-20240816173323833

05. left 函数

  • 从字符串的第一个字符开始,向后截取指定 length 个字符。

image-20240816173813305

  • 如果 length 超过了字符串的长度,则截取整个字符串。

image-20240816173836434

06. length 函数

  • 获取指定字符串所占用的字节数。
    • 在不同的编码格式中,一个字节所占空间大小是有区别的,如:utf8 下一个字符占 3 字节,而 gbk 下一个字符占 2 字节。

image-20240816174150169

07. replace 函数

  • 将字符串中的指定子串替换成另一个字符串,只是字符串级别的替换,并不会变更表中原有的数据。
    • 例:将张三的三替换成角。

image-20240816175755615

08. strcmp 函数

  • 使用起来和 C 语言的 strcmp 函数一致,就是逐字符按照 ASCII 码比较两个字符串,两个串相等则返回 0,串1 > 串2 则返回 1,串2 > 串1 则返回 -1.

image-20240816180138521

09. substring 函数

  • 返回从起始位置开始的 len 个字符。

image-20240816180700312

  • 不指定 len 的话则默认返回从 start 开始的所有字符。

image-20240816180824700

10. ltrim、rtrim、trim

  • ltrim 函数:去掉字符串左边的空格。

image-20240816181529980

  • rtrim 函数:去掉字符串右边的空格。

image-20240816181549971

  • trim 函数:去掉字符串左右两边的空格。

image-20240816181609922

⭐ 3. 字符串函数综合案例

  • 当前有一张名为 emp 的员工表。

image-20240816183040074

以首字母小写的方式显示员工表中所有员工的姓名

  • 使用 substring 函数,截取员工姓名的第一个字符,然后使用 lower 函数将其转换成小写字母。
  • 使用 substring 函数,截取员工姓名从第二个开始的所有字符。
  • 使用 concat 函数,将前两次截取出来的字符串进行拼接,即可获得首字母小写的员工姓名了。

image-20240816183436968

🌈 三、数值函数

⭐ 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 函数

  • 获取一个数的绝对值。

image-20240816185533097

02. bin 函数

  • 建一个十进制整数转换成二进制。

image-20240816185629202

03. hex 函数

  • 将一个十进制整数转换成十六进制。

image-20240816185725158

04. conv 函数

  • 将一个数从一个进制转换成另一个进制。

image-20240816190002595

05. ceil 函数

  • 对一个数进行向上取整。

image-20240816190326787

  • 向上取整本质是向正无穷方向取整,负数向上取整之后得到的是第一个大于等于该数的值。

image-20240816190400468

06. floor 函数

  • 对一个整数进行向下取整。

image-20240816190517944

  • 向下取整本质是向负无穷方向取整,负数向上取整之后得到的是第一个小于等于该数的值。

image-20240816190551868

07. format 函数

  • 对数值进行格式化,以四舍五入的形式保留指定的小数点后的数字。

image-20240816190848832

08. rand 函数

  • 生成一个 0 ~ 1 之间的随机浮点数。

image-20240816191000781

  • 如果想生成的是 0 ~ n 之间的随机数,可以让 rand() 函数生成的随机数与 n 相乘,在对相乘后的结果取整即可。
    • 例:生成一个 0 ~ 10 之间的随机数。

image-20240816191253023

09. mod 函数

  • 没啥可说的,就是求 参数1 % 参数2 后的值而已。

image-20240816191404301

🌈 四、流程函数

⭐ 1. 常见流程函数

函数说明
if(value, t, f)如果 value 为 true,则返回 t,否则返回 f
ifnull(value1, vaule2)如果 value1 不为空,则返回 value1,否则返回 value2

⭐ 2. 流程函数使用示例

01. if 函数

  • 如果参数 1 的值为 true,则返回参数 2,否则返回参数 3。

image-20240816192235578

02. ifnull 函数

  • 如果参数 1 不为空,则返回参数 1,否则返回参数 2。

image-20240816192452957

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值