第十篇:MySQL内置函数(字符串函数|数值函数|日期函数|流程函数)

本文主要是介绍第十篇:MySQL内置函数(字符串函数|数值函数|日期函数|流程函数),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

函数就是一段写好的、具有特定功能的代码,可以被另一段程序直接调用,只要拥有编程基础。想必对函数并不陌生

本篇将系统性地记录MySQL中常用的内置函数,主要分为这四大类,

  • 字符串函数
  • 数值函数
  • 日期函数
  • 流程函数


一,字符串函数

(一)concat(S1, S2,...Sn) <-拼接

作用描述

将传入的多个子字符串拼接成一个母字符串后,返回母串

实例演示

如下图,使用concat()函数对3个子串进行拼接后使用【select】关键字输出的结果是3个子串拼接成的母串

(二)lower(str) <-小写字母化

作用描述

将字符串str中的所有字母全部小写化,非字母字符则不做处理

实例演示

如下图,使用lower()函数对字符串【"@#MySQL!%"】小写字母化后,使用【select】关键字输出,结果显示大写字母均变为小写字母

(三)upper(str) <-大写字母化

作用描述

将字符串str中的所有字母全部大写化,非字母字符则不做处理

实例演示

如下图,使用upper()函数对字符串【"@#MySQL!%"】大写字母化后,使用【select】关键字输出,结果显示小写字母均变为大写字母

(四)lpad(str, n, pad) <-左填充

作用描述

使用pad字符从左边去填充字符串str,使其长度为n

实例演示

例如需要在最大长度为5的id前面补前导0,长度不足5就补0,满足长度为5就不补

(五)rpad(str, n, pad) <-右填充

作用描述

使用pad字符从右边去填充字符串str,直至填充后的字符串长度为n

实例演示

和【一.(四)】的lpad()函数同理,不多做说明

(六)trim(str) <-去除头尾空格

作用描述

将字符串str头尾(即左右两边)的空格全部去除,对于字符中间的空格则不做处理

实例演示

(七)substring(str, start, len) <-截取字符串

作用描述

从索引start开始截取字符串str,直至截取出的字符串满足长度为len

注意:

  • 不同于一般编程语言的字符串索引起始为0,该函数默认字符串的索引起始为1(即第一个字符的索引/下标被视为1)
  • 使用该函数截取字符串时,截取出的子串长度小于等于str

实例演示


 二,数值函数

(一)ceil(x) <-向上取整

作用描述

对浮点数x向上取整,

实例演示

(二)floor(x) <-向下取整

作用描述

对浮点数x向下取整

实例演示

(三)mod(x, y) <-取模(求余数)

作用描述

计算x除以y的余数,即求x%y

实例演示

(四)rand() <-获取0~1随机数

作用描述

产生0到1的随机浮点数

实例演示

(五)round(x, y) <-四舍五入x保留y位小数

作用描述

对x四舍五入并保留y位小数

实例演示


 三,日期函数

(一)curdate() <-返回当前年月日

作用描述

返回当前日期,结果由【yyyy-mm-dd】格式的年月日组成

实例演示

(二)curtime() <-返回当前时分秒

作用描述

返回当前时刻,结果由【hh:mm:ss】格式的时分秒组成

实例演示

(三)now() <-返回当前年月日和时分秒

作用描述

返回当前日期和时刻,结果由【yyyy-mm-dd hh:mm:ss】格式的年月日时分秒组成

实例演示

(四)year(date) <-获取指定date的年份

作用描述

从格式为【yyyy分隔符mm分隔符dd】的字符串date中获取年份

  • 此处的date字符串中,年月日的分隔符可以是【减号(-)or冒号(:)or左斜杠(/)or竖线(|)or加减乘除模(+-*/%)】等多种符号类字符,但不能是右斜杠(\)
  • 该字符串允许在末尾加上时分秒
  • 给出的年月日需要在合法日期中,例如不存在13月份,32号等

实例演示

(五)month(date) <-获取指定date的月份

作用描述

作用是获取月份,规则和【三.(四)】的year(date)函数一致

实例演示

(六)day(date) <-获取指定date的日期

作用描述

作用是获取月份,规则和【三.(四)】的year(date)函数一致

实例演示

(七)date_add(date, interval expr type) <-返回当前日期加上expr后的时间

作用描述

date是从格式为【yyyy分隔符mm分隔符dd】的字符串,interval是固定的参数,expr是间隔数值,type是类型,有year,month,day分别代表年月日,该函数会计算传入的时间加上间隔expr个type之后的时间

  • 此处的date字符串中,年月日的分隔符可以是【减号(-)or冒号(:)or左斜杠(/)or竖线(|)or加减乘除模(+-*/%)】等多种符号类字符,但不能是右斜杠(\)
  • 该字符串允许在末尾加上时分秒
  • 给出的年月日需要在合法日期中,例如不存在13月份,32号等

实例演示

(八)datediff(date1, date2) <-返回时间段之间的天数

作用描述

date1和date2是从格式为【yyyy分隔符mm分隔符dd】的字符串,该函数将计算date1减去date2的天数(即从date2到date1需要过多少天)

  • 此处的date字符串中,年月日的分隔符可以是【减号(-)or冒号(:)or左斜杠(/)or竖线(|)or加减乘除模(+-*/%)】等多种符号类字符,但不能是右斜杠(\)
  • 该字符串允许在末尾加上时分秒
  • 给出的年月日需要在合法日期中,例如不存在13月份,32号等

实例演示


四,流程(条件判断)函数

(一)if(value, t, f) <-判断value的真假

作用描述

如果value为true,返回t,否则返回f

实例演示

(二)ifnull(value1, value2) <-判断null值

作用描述

如果value1为null,返回value2,否则返回value1,注意,这里的null指的是空值,类似空字符("")和整数0等并不属于空值,易混淆

实例演示

(三) case expr when val1 then res1...else default end

作用描述

如果expr的值等于val1,返回res1,...否则返回default

(有点难描述,其实就相当于C/C++/Java里面的if...else if...else if...else)

实例演示

(不便直接演示所以直接搬视频截图了,理解记忆就好!)

这篇关于第十篇:MySQL内置函数(字符串函数|数值函数|日期函数|流程函数)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/823449

相关文章

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链

linux环境openssl、openssh升级流程

《linux环境openssl、openssh升级流程》该文章详细介绍了在Ubuntu22.04系统上升级OpenSSL和OpenSSH的方法,首先,升级OpenSSL的步骤包括下载最新版本、安装编译... 目录一.升级openssl1.官网下载最新版openssl2.安装编译环境3.下载后解压安装4.备份

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据

《mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据》文章主要介绍了如何从.frm和.ibd文件恢复MySQLInnoDB表结构和数据,需要的朋友可以参... 目录一、恢复表结构二、恢复表数据补充方法一、恢复表结构(从 .frm 文件)方法 1:使用 mysq

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

MySQL进阶之路索引失效的11种情况详析

《MySQL进阶之路索引失效的11种情况详析》:本文主要介绍MySQL查询优化中的11种常见情况,包括索引的使用和优化策略,通过这些策略,开发者可以显著提升查询性能,需要的朋友可以参考下... 目录前言图示1. 使用不等式操作符(!=, <, >)2. 使用 OR 连接多个条件3. 对索引字段进行计算操作4