【MySQL】内置函数

目录

一、日期函数

1、获得年月日

2、获得时分秒

3、获得时间戳

4、在日期的基础上加日期

5、在日期的基础上减去时间

6、计算两个日期之间相差多少天

7、案例

二、字符串函数

1、获取emp表的ename列的字符集

2、要求显示exam_result表中的信息

3、求学生表中学生姓名占用的字节数

4、将EMP表中所有名字中有S的替换成'上海'

5、截取EMP表中ename字段的第二个到第三个字符

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

三、数学函数

1、绝对值

2、向上取整

3、向下取整

4、保留2位小数位数(小数四舍五入)

[5、 产生随机数](#5、 产生随机数)

四、其他函数

1、user()

2、md5(str)

3、database()

4、password()

[5、ifnull(val1, val2)](#5、ifnull(val1, val2))


一、日期函数

1、获得年月日

复制代码
select current_date();

2、获得时分秒

复制代码
select current_time();

3、获得时间戳

复制代码
select current_timestamp();

4、在日期的基础上加日期

复制代码
select date_add('[指定日期]', interval [数字] [d_value_type]);

5、在日期的基础上减去时间

复制代码
select date_sub('[指定日期]', interval [数字] [d_value_type]);

6、计算两个日期之间相差多少天

复制代码
select datediff('[日期1]', '[日期2]');

7、案例

创建一个留言表

插入数据

显示所有留言信息,发布日期只显示日期,不用显示时间

请查询在2分钟内发布的帖子

二、字符串函数

1、获取emp表的ename列的字符集

复制代码
select charset(ename) from EMP;

2、要求显示exam_result表中的信息

显示格式:"XXX的语文是XXX分,数学XXX分,英语XXX分":

复制代码
select concat(name, '的语文是', chinese, '分,数学是', math, '分') '分数' from exam_result;

3、求学生表中学生姓名占用的字节数

复制代码
select length(name), name from students;

注意:length函数返回字符串长度,以字节为单位。如果是多字节字符则计算多个字节数。如果是单字节字符则算作一个字节。比如:字母,数字算作一个字节,中文表示多个字节数(与字符集编码有关)。

4、将EMP表中所有名字中有S的替换成'上海'

复制代码
select replace(ename, 'S', '上海') ,ename from EMP;

5、截取EMP表中ename字段的第二个到第三个字符

复制代码
select substring(ename, 2, 2), ename from EMP;

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

复制代码
select concat(lcase(substring(ename, 1, 1)),substring(ename,2)) from EMP;

三、数学函数

1、绝对值

复制代码
select abs(-100.2);

2、向上取整

复制代码
select ceiling(23.04);

3、向下取整

复制代码
select floor(23.7);

4、保留2位小数位数(小数四舍五入)

5、 产生随机数

复制代码
select rand();

四、其他函数

1、user()

查询当前用户:

2、md5(str)

对一个字符串进行md5摘要,摘要后得到一个32位字符串:

复制代码
select md5('admin');

3、database()

显示当前正在使用的数据库:

4、password()

MySQL数据库使用该函数对用户加密:

5、ifnull(val1, val2)

如果val1为null,返回val2,否则返回val1的值。

相关推荐
数据库那些事儿14 小时前
Qoder + ADB Supabase :5分钟GET超火AI手办生图APP
数据库·后端
IvorySQL14 小时前
PostgreSQL 18 异步 I/O(AIO)调优指南
数据库·postgresql
kakacc:15 小时前
记录一次巧妙的SQL:一对多关联导致的 sum () 、count()等group函数重复计算问题
数据库·sql
心随雨下15 小时前
Redis中Geospatial 实际应用指南
数据库·redis·分布式·缓存
黑夜管理员15 小时前
Sql Server安装报错“服务没有及时响应启动或控制请求”
数据库·sql server
NineData15 小时前
NineData云原生智能数据管理平台新功能发布|2025年9月版
数据库·云原生·devops·ninedata·数据库迁移·数据复制·风险sql管控
junnhwan16 小时前
【苍穹外卖笔记】Day04--套餐管理模块
java·数据库·spring boot·后端·苍穹外卖·crud
川石课堂软件测试16 小时前
全链路Controller压测负载均衡
android·运维·开发语言·python·mysql·adb·负载均衡
一枚正在学习的小白16 小时前
PG数据文件位置迁移
linux·运维·服务器·数据库
真的想不出名儿16 小时前
上传头像到腾讯云对象存储-前端基于antdv
java·数据库·腾讯云