news 2026/2/3 4:44:34

MySQL内置函数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
MySQL内置函数

1. 日期函数

函数名称描述
current_date()当前日期
current_time()当前时间
current_timestamp()当前时间戳
date(datetime)返回 datetime 参数的日期部分
date_add(date, interval d_value_type)在 date 中添加日期或时间interval 后的数值单位可以是:year minute second day
date_sub(date, interval d_value_type)在 date 中减去日期或时间interval 后的数值单位可以是:year minute second day
datediff(date1, date2)两个日期的差,单位是天
now()当前日期时间
  • 在日期的基础上加日期
    select date_add('2017-10-28', interval 10 day); +-----------------------------------------+ | date_add('2017-10-28', interval 10 day) | +-----------------------------------------+ | 2017-11-07 | +-----------------------------------------+
  • 计算两个日期之间相差多少天
    select datediff('2017-10-10', '2016-9-1'); +------------------------------------+ | datediff('2017-10-10', '2016-9-1') | +------------------------------------+ | 404 | +------------------------------------+
  • 案例:创建一个留言表
    -创建一个留言表 mysql> create table msg ( -> id int primary key auto_increment, -> content varchar(30) not null, -> sendtime datetime -> ); Query OK, 0 rows affected (0.02 sec) mysql> insert into msg(content,sendtime) values('hello1', now()); Query OK, 1 row affected (0.01 sec) mysql> insert into msg(content,sendtime) values('hello2', now()); Query OK, 1 row affected (0.00 sec) mysql> select * from msg; +----+---------+---------------------+ | id | content | sendtime | +----+---------+---------------------+ | 1 | hello1 | 2025-12-14 10:59:45 | | 2 | hello2 | 2025-12-14 10:59:45 | +----+---------+---------------------+ 2 rows in set (0.00 sec) -显示所有留言信息,发布日期只显示日期,不用显示时间 mysql> select id,content,date(sendtime) from msg; +----+---------+----------------+ | id | content | date(sendtime) | +----+---------+----------------+ | 1 | hello1 | 2025-12-14 | | 2 | hello2 | 2025-12-14 | +----+---------+----------------+ 2 rows in set (0.00 sec) -查询在2分钟内发布的帖子 mysql> insert into msg (content,sendtime) value('straykids',now()); Query OK, 1 row affected (0.00 sec) mysql> select *from msg where date_add(sendtime,interval 2 minute) >now(); +----+-----------+---------------------+ | id | content | sendtime | +----+-----------+---------------------+ | 3 | straykids | 2025-12-14 11:04:48 | +----+-----------+---------------------+

    2. 字符函数

函数功能
charset(str)返回字符串字符集
concat(string2 [,…])连接字符串
instr(string, substring)返回 substring 在 string 中出现的位置,没有返回 0
ucase(string2)转换成大写
lcase(string2)转换成小写
left(string2, length)从 string2 中的左边起取 length 个字符
length(string)string 的长度
replace(str, search_str, replace_str)在 str 中用 replace_str 替换 search_str
strcmp(string1, string2)逐字符比较两字符串大小
substring(str, position [,length])从 str 的 position 开始,取 length 个字符
ltrim(string)、rtrim(string)、trim(string)去除前空格或后空格
  • 返回字符串字符集
    mysql> select charset('abskdfhlfhfo654'); +----------------------------+ | charset('abskdfhlfhfo654') | +----------------------------+ | utf8 | +----------------------------+ 1 row in set (0.00 sec)
  • 显示exam_result表中的信息,显示格式:“XXX的语文是XXX分,数学XXX分,英语XXX分
    select concat(name, '的语文是',chinese,'分,数学是',math,'分') as '分数' from student;
  • 求学生表中学生姓名占用的字节数
    select length(name), name from student;

    :length函数返回字符串长度,以字节为单位。如果是多字节字符则计算多个字节数; 如果是单字节字符则算作一个字节。比如:字母,数字算作一个字节,中文表示多个字节数 (utf-8中文算三个字节)

    mysql> select length('123哈哈'); +---------------------+ | length('123哈哈') | +---------------------+ | 9 | +---------------------+ 1 row in set (0.00 sec)
  • 将EMP表中所有名字中有S的替换成'上海'
select replace(ename, 'S', '上海') ,ename from EMP;
  • 截取EMP表中ename字段的第二个到第三个字符
    select substring(ename, 2, 2), ename from EMP;
  • 以首字母小写的方式显示所有员工的姓名
    select concat(lcase(substring(ename, 1, 1)),substring(ename,2)) from EMP;

    3. 数字函数

函数名称描述常见用途
abs(number)绝对值函数处理数值的非负表示
bin(decimal_number)十进制转换二进制二进制数据处理、位运算场景
hex(decimalNumber)转换成十六进制内存地址、编码表示等场景
conv(number, from_base, to_base)进制转换多进制(如 2、8、10、16)间的数值转换
ceiling(number)向上取整资源分配、数量计算的向上估算
floor(number)向下取整数据分组、数量计算的向下估算
format(number, decimal_places)格式化,保留小数位数数值展示的精度控制
rand()返回随机浮点数,范围 [0.0,1.0)随机抽样、模拟场景等
mod(number, denominator)取模,求余周期判断、分组标识等
  • 绝对值
    select abs(-100.2);
  • 向上取整
    select ceiling(23.04);
  • 向下取整
    select floor(23.7);
  • 保留2位小数位数(小数四舍五入)
    select format(12.3456, 2);
  • 产生随机数
    select rand();

    4. 其它函数

  • user() 查询当前用户
    select user();
  • md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串
    -将任意长度的输入数据映射为固定长度的 128 位哈希值(32 位十六进制字符串) -本质是实现数据的 “指纹” 标识 select md5('admin') +----------------------------------+ | md5('admin') | +----------------------------------+ | 21232f297a57a5a743894a0e4a801fc3 | +----------------------------------+
  • database()显示当前正在使用的数据库
    select database();
  • password()函数,MySQL数据库使用该函数对用户加密
    select password('root'); +-------------------------------------------+ | password('root') | +-------------------------------------------+ | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B | +-------------------------------------------+ 或者想要加密密码可以使用md5函数 但是存入md5函数查询也要使用 mysql> create table user_p ( -> name char(20), -> password varchar(32)); Query OK, 0 rows affected (0.02 sec) mysql> INSERT INTO user_p (name,password) VALUES ('lex', md5('134565')); Query OK, 1 row affected (0.01 sec) mysql> select name from user_p where password=md5('134565'); +------+ | name | +------+ | lex | +------+ 1 row in set (0.00 sec)
  • ifnull(val1, val2) 如果val1为null,返回val2,否则返回val1的值
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/2 23:22:03

5分钟极速上手DevToys:开发者必备的效率神器终极指南

还在为日常开发中那些琐碎的工具切换而烦恼吗?😫 JSON格式化要开浏览器、Base64编码得找在线工具、正则测试又要切换网站...现在,一款名为DevToys的开发者工具箱彻底解决了这些痛点!这款开源效率工具集成了30实用功能,…

作者头像 李华
网站建设 2026/2/2 23:22:14

2025年AI证书盘点:为何CAIE成为众多专业人士的备考选择?

全球人工智能产业正以前所未有的速度扩张,据国际数据公司(IDC)统计,2024年全球AI解决方案支出达到2500亿美元,预计2027年将突破5000亿美元。中国信息通信研究院数据显示,中国AI核心产业规模持续增长&#x…

作者头像 李华
网站建设 2026/2/2 23:33:22

如何选择最适合的智能家居集成方案?

如何选择最适合的智能家居集成方案? 【免费下载链接】hass-xiaomi-miot Automatic integrate all Xiaomi devices to HomeAssistant via miot-spec, support Wi-Fi, BLE, ZigBee devices. 小米米家智能家居设备接入Hass集成 项目地址: https://gitcode.com/gh_mir…

作者头像 李华
网站建设 2026/2/3 1:05:21

80亿参数硬刚720亿!MiniCPM-V 4.5重新定义端侧多模态AI效率天花板

80亿参数硬刚720亿!MiniCPM-V 4.5重新定义端侧多模态AI效率天花板 【免费下载链接】MiniCPM-V-4_5 MiniCPM-V 4.5 是 MiniCPM-V 系列中最新且功能最强的模型。该模型基于 Qwen3-8B 和 SigLIP2-400M 构建,总参数量为 80 亿。与之前的 MiniCPM-V 和 MiniCP…

作者头像 李华
网站建设 2026/2/2 6:48:49

23、Python Web开发:Django与Flask实战指南

Python Web开发:Django与Flask实战指南 一、Django应用开发 1.1 安装Django 在安装Django之前,你需要确保已经安装了Python。以下是创建Django项目的详细步骤: 1. 创建虚拟环境 : - 为项目创建一个新目录,并在新的终端窗口中进入该目录。 - 使用以下命令创建一个新…

作者头像 李华