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

news2024/9/21 22:36:14

文章目录

  • 🌈 一、日期函数
    • ⭐ 1. 常见日期函数
    • ⭐ 2. 日期函数使用示例
    • ⭐ 3. 日期函数综合案例
  • 🌈 二、字符串函数
    • ⭐ 1. 常见字符串函数
    • ⭐ 2. 字符串函数使用示例
    • ⭐ 3. 字符串函数综合案例
  • 🌈 三、数值函数
    • ⭐ 1. 常见数值函数
    • ⭐ 2. 数值函数使用示例
  • 🌈 四、流程函数
    • ⭐ 1. 常见流程函数
    • ⭐ 2. 流程函数使用示例

在这里插入图片描述

🌈 一、日期函数

⭐ 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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2054582.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

探索GitHub的无限可能:从注册到Linux环境下的库分支链接

在这个数字化时代,GitHub已成为开发者们不可或缺的宝藏库。无论你是编程新手还是资深开发者,GitHub都能为你打开一扇通往无限创意与协作的大门。今天,就让我们一起踏上这段探索之旅,从GitHub的注册开始,再到如何在Linu…

google transalte api的使用,V2服务账户方式(google-cloud-java)

Google Cloud Translation API 有几个不同的使用方式,其中之一是使用最新的 Google Cloud Client Library。这些库提供了简化的 API,使得与 Google Cloud 服务的交互变得更加容易。 对于gcp平台的创建方式,我记得得绑定真信用卡了&#xff0c…

Debug-021-el-table实现分页多选的效果(切换分页,仍可以保持前一页的选中效果)

前情提要: 这个功能实现很久了,但是一直没有留意如何实现,今天想分享一下。具体就是我们展示table数据的时候,表格中的数据多数情况是分页展示,毕竟数据量太多,分页的确是有必要的。那么我们有业务需要给表…

portswigger的Exploiting DOM clobbering to enable XSS

目录 尝试一下看看可不可以XSS DOM破坏 查看源码确定DOM破坏漏洞点以及代码分析 首先查看/resources/labheader/js/labHeader.js,没有什么作用 然后domPurify这东西是一个过滤框架也没啥子用 看/resources/js/loadCommentsWithDomClobbering.js尝试分析代码(对…

使用Poi-tl对word模板生成动态报告

一、pom依赖问题&#xff1a; <dependency> <groupId>com.deepoove</groupId> <artifactId>poi-tl</artifactId> <version>1.12.2</version> </dependency> 使用 poi-tl 的 1.12.2版本&#xff0c;如果使用了poi依赖&#x…

【编程之路:在 Bug 的迷宫中寻找出口】

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

Mysql-linux通过rpm安装、linux离线安装mysql

新建用户 useradd mysql passwd mysqlmysql用户增加sudo权限 Linux-创建用户、给普通用户sudo权限、设置不需要密码执行sudo 卸载旧版本软件包 卸载mariadb --查询mariadb版本 rpm -qa|grep mariadb --控制台输出 mariadb-libs-5.5.68-1.el7.x86_64 --执行卸载 sudo rpm -…

系规学习第13天

1、规划设计的主要目的不包括() A、设计满足业务需求的IT服务 B、设计SLA、测量方法和指标。 C、设计服务过程及其控制方 D、设计实施规划所需要的进度管理过程 [答案] D [解析]本题考察的是规划设计的目的&#xff0c;建议掌握。 (1)设计满足业务需求的IT服务。 (2)设…

Python计算机视觉 第1章-基本的图像操作和处理

Python计算机视觉 第1章-基本的图像操作和处理 本章讲解操作和处理图像的基础知识&#xff0c;将通过大量示例介绍处理图像所需的Python工具包&#xff0c;并介绍用于读取图像、图像转换和缩放、计算导数、画图和保存结果等的基本工具。 1.1 PIL&#xff1a;Python图像处理类…

零基础学习Redis(4) -- 常用数据结构介绍

我们之前提到过&#xff0c;redis中key只能是字符串类型&#xff0c;而value有多种类型。 redis中的数据结构有自己独特的实现方式能根据特定的场景进行优化 1. string(字符串) 内部编码&#xff1a; raw&#xff1a;最基本的字符串&#xff0c;类比我们平常使用的Stringin…

MFC读取 Excel

2.添加读取excel数据的接口类&#xff1a; 添加读取excel的接口类&#xff1a; 3、添加完成后&#xff0c;找到这几个接口类的头文件&#xff0c;注释/删除 下图红框中的引入语句 注意&#xff1a;每个接口类的头文件都需进行处理。 4、添加源文件 excel.h文件&#xff1a; …

Spring websocket并发发送消息异常的解决

https://www.jb51.net/program/297186nkq.htm本文主要介绍了 Spring websocket并发发送消息异常的解决,当多个线程同时尝试通过 WebSocket 会话发送消息时,会抛出异常,下面就来解决一下,感兴趣的可以了解一下https://www.jb51.net/program/297186nkq.htm

centos系统配置转发和iptables使之成为网关

centos系统配置转发和iptables使之成为网关 在当下互联网环境中&#xff0c;有很多内网服务器不能出网&#xff0c;例如安装软件包&#xff0c;更新程序之类的&#xff0c;偶尔会需要出网&#xff0c;下面这种方式就是专门解决这个事情的。 如下配置在 centos 6 7 8 rocky 8 …

FPGA 最小系统 EP2C5T144C8N

参考 &#xff1a; 微雪 ep2c5t 米尔 所需元件&#xff1a; 1.2v 3.3v稳压芯片 7个10k电阻 一个use blast 5v-》3.3v稳压-》1.2v稳压 1.JTAG连接 JTAG连接 NSTATUS nconfig config_done 因为没有外部存储器&#xff0c;直接使用Jtag烧录&#xff0c;从而nconfig 为3.3 &…

全场景——(三)USB开发基础(2)

文章目录 一、USB 描述符1.1 USB 设备状态切换图1.2 标准设备请求1.2.1 SETUP事务的数据格式1.2.2 标准设备请求1.2.3 设备/配置/接口/端点 1.3 描述符1.3.1 设备描述符1.3.2 配置描述符1.3.3 接口描述符1.3.4 端点描述符1.3.5 示例 1.4 设备枚举过程示例 二、USBX 组件2.1 Azu…

Rhinoceros 8 for Mac/Win:重塑三维建模边界的革新之作

Rhinoceros 8&#xff08;简称Rhino 8&#xff09;&#xff0c;作为一款由Robert McNeel & Assoc公司开发的顶尖三维建模软件&#xff0c;无论是对于Mac还是Windows用户而言&#xff0c;都是一款不可多得的高效工具。Rhino 8以其强大的功能、广泛的应用领域以及卓越的性能&…

阿里云发送短信功能(Java)

&#xff08;1&#xff09;注册用户&#xff0c;并且开通短信套餐 &#xff08;2&#xff09; 点击快速学习&#xff0c;然后绑定测试的手机号码。 选用专用测试签名&#xff08;自定义的话阿里可能会验证什么什么的比较麻烦&#xff09; 然后在选取调用API &#xff08;3&…

Excel ——3个实用的随机函数(RAND 、RANDBETWEEN、RANDARRAY)

1、RAND 函数 RAND 函数是一个没有参数的函数&#xff1a;RAND () 返回一个大于等于 0&#xff0c;小于 1 的随机实数。 选中任一单元格&#xff0c;在编辑栏输入公式&#xff1a; 如果要生成 a 与 b 之间的随机数&#xff0c;就用&#xff1a; RAND()*(b-a)a 比如要生成-5…

Docker Compose运行Elasticsearch

前提&#xff1a;确保你已经安装了Docker和Docker Compose 创建项目目录 创建一个目录来存放项目文件 mkdir es cd es 创建docker-compose.yml文件 touch docker-compose.yml version: 3.3 services: elasticsearch: image: docker.elastic.co/elasticsearch/elastics…

mysql windows、Ubuntu安装与远程连接配置

下载 在Windows下安装MySQL需要在官网下载安装包 官网地址www.mysql.com 找到社区下载 选择适用于Windows的MYSQL安装程序 选择自己电脑对应的版本和所要下载的mysql版本一般是5.7版本和8.0版本 按照图片上的选项进行安装 到此就安装完成了 需要自己手动配置环境变量…