文章目录
- MySQL
-
- [1. 日期函数](#1. 日期函数)
-
- [1.1 查看时间](#1.1 查看时间)
- [1.2 对时间进行计算](#1.2 对时间进行计算)
- [2. 字符串函数](#2. 字符串函数)
-
- [2.1 字符串查找](#2.1 字符串查找)
- [2.2 字符串修改显示](#2.2 字符串修改显示)
- [3. 数学函数](#3. 数学函数)
- [4. 聚合函数](#4. 聚合函数)
- [5. 其他函数](#5. 其他函数)
MySQL
data:image/s3,"s3://crabby-images/d547e/d547e8a21ce0b86495661a3617922f43b02e7a7a" alt=""
1. 日期函数
在MySQL中,提供了多种时间函数供我们使用,其中包括用于查看时间的函数和计算日期的函数。以下是一些常用的MySQL时间函数及其描述:
函数名称 | 描述 |
---|---|
current date() | 当前日期 |
current time() | 当前时间 |
current timestamp() | 当前时间戳 |
date(datetime) | 返回datetime参数的日期部分 |
date add(date, interval d value type) | 在date中添加日期或时间,interval后的数值单位可以是:year minute secondday |
date sub(date, interval d value type) | 在date中减去日期或时间,interval后的数值单位可以是:year minute second day |
datediff(datel, date2) | 两个日期的差,单位是天 |
now() | 当前日期时间 |
1.1 查看时间
获取当前的年月日:
sql
select current_date();
data:image/s3,"s3://crabby-images/d7c32/d7c32aa2945312128e3c2abad6dde71f4c4cf166" alt=""
获取当前的时分秒:
sql
select current_time();
data:image/s3,"s3://crabby-images/aa5f0/aa5f03811a91aead6fd896697c593a3e9935c3b9" alt=""
获取当前的时间戳:
这里的时间戳相当于是年月日加上时分秒。
sql
select current_timestamp();
data:image/s3,"s3://crabby-images/09698/096985412682913bfaa769b5b7f560cfb680d521" alt=""
1.2 对时间进行计算
在日期的基础上加日期:
DATE_ADD() 是 MySQL 中的一个函数,用于在日期上添加指定的时间间隔。它的语法如下:
sql
DATE_ADD(date, INTERVAL expr unit);
date 是要操作的日期值。
expr 是希望添加的时间间隔数值。
unit 是时间间隔的单位,例如 DAY、MONTH、YEAR 等。
sql
select date_add('2024-3-17',interval 10 day);
data:image/s3,"s3://crabby-images/bbb36/bbb36904d92e6bf668d2e1c82b86d4e40ff0f40e" alt=""
在日期的基础上减去时间:
DATE_SUB() 是 MySQL 中的一个函数,用于从日期时间值中减去指定的时间间隔。它允许你根据需求在日期或日期时间字段中减去年、月、日、小时、分钟或秒钟等时间单位。以下是 DATE_SUB() 函数的基本语法:
sql
DATE_SUB(date, INTERVAL expr unit);
date 是要进行调整的日期或日期时间表达式。
expr 是一个表示时间间隔大小的表达式,可以是一个整数或者一个与 date 类型相同的表达式。
unit 是时间单位,如 YEAR、MONTH、DAY、HOUR、MINUTE、SECOND 等。
sql
select date_sub('2024-3-17',interval 10 day);
data:image/s3,"s3://crabby-images/efb56/efb5666cce7819808fe8e435067ecf8e7e842d7c" alt=""
计算两个日期之间相差多少天:
DATEDIFF 用于计算两个日期之间的差异。以下是 DATEDIFF 函数的介绍:
sql
DATEDIFF(end_date, start_date);
end_date:表示要计算的时间段的结束日期。
start_date:表示要计算的时间段的开始日期。
sql
select datediff('2024-3-17','2023-3-17');
data:image/s3,"s3://crabby-images/16c39/16c39ed70047573a0860df07a946d0363b00d5c1" alt=""
例子:创建一张留言表,用于记录用户发送信息的时间:
我们使用 id 作为主键同时进行自增长,设置内容不为空,同时包含一个 datetime 类型的变量 sendtime 。
sql
mysql> create table msg(
-> id int primary key auto_increment,
-> content varchar(30) not null,
-> sendtime datetime
-> );
data:image/s3,"s3://crabby-images/b8be6/b8be669b562269ebad9f00afb71f18cc415f71d7" alt=""
打印表结构:
sql
desc msg;
data:image/s3,"s3://crabby-images/a6991/a6991141033fd532f5fd6fb7e0f13d49aea9ccf7" alt=""
插入数据并且打印所有信息:
sql
mysql> insert into msg(content,sendtime) values('hello',now());
mysql> insert into msg(content,sendtime) values('你好',now());
mysql> insert into msg(content,sendtime) values('你也好',now());
data:image/s3,"s3://crabby-images/3fccb/3fccb7423181ce803c5eac2fb33f97e736387ee5" alt=""
sql
select * from msg;
data:image/s3,"s3://crabby-images/3e193/3e193cb8dd7d1efc9dc38d4f9aac0491711831e6" alt=""
打印所有留言信息,只显示日期,不显示时间:
sql
select content ,date(sendtime) from msg;
data:image/s3,"s3://crabby-images/ad427/ad4279c3fb0518e6db408955bc65575d31a226fe" alt=""
打印所有留言信息,只显示时间,不显示日期:
sql
select content ,time(sendtime) from msg;
data:image/s3,"s3://crabby-images/5f51d/5f51deb5eb8397331cd1b57ae8d3f3712f66928a" alt=""
只打印两分钟之内发布的信息:
sql
select * from msg where date_add(sendtime,interval 2 minute)>now();
data:image/s3,"s3://crabby-images/71d1f/71d1f954b96eeae95607720aeede3446d53618aa" alt=""
2. 字符串函数
MySQL 提供了许多字符串函数,用于在查询中处理和操作字符串数据。以下是一些常用的 MySQL 字符串函数及其描述:
函数名称 | 描述 |
---|---|
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(stringl, string2) | 逐字符比较两字符串大小 |
substring(str,position length]) | 从str的postion开始,取length个字符 |
ltrim(string) rtrim(string)trim(string) | 去除前空格或后空格 |
2.1 字符串查找
创建一张表其中包括学生的 id 、姓名和语文数学成绩:
sql
mysql> create table emp(
-> id int primary key auto_increment,
-> chinese int comment '语文成绩',
-> math int comment '数学成绩',
-> name varchar(20)
-> );
data:image/s3,"s3://crabby-images/c4efb/c4efb191e51f0372987026d31b399e3e326a2e42" alt=""
插入学生的信息并且打印查看:
sql
mysql> insert into emp(chinese,math,name) values(90,70,'张三');
mysql> insert into emp(chinese,math,name) values(87,70,'李四');
mysql> insert into emp(chinese,math,name) values(85,80,'王五');
mysql> select * from emp;
data:image/s3,"s3://crabby-images/677ec/677eccc59c5d94f54358f183af47eefb6a3856ab" alt=""
获取emp表的name列的字符集:
sql
select charset(name) from emp;
data:image/s3,"s3://crabby-images/99feb/99feb936cb4ca100d7f49b69e9c58fee5a19d6d6" alt=""
要求显示emp表中的信息,显示格式:"XXX的语文是XXX分,数学XXX分":
CONCAT函数用于连接两个或多个字符串值,并返回连接后的字符串。这个函数非常有用,特别是当我们需要将多个字段或值组合成一个字符串时。
sql
CONCAT(str1, str2, ..., strN)
str1, str2, ..., strN:这是要连接的字符串。它们可以是字符串值、列名、其他CONCAT函数,或者返回字符串值的表达式。
CONCAT函数返回一个字符串,该字符串是输入字符串参数的连接。
sql
select concat(name,'的语文成绩为',chinese,'分,数学成绩为',math,'分')
as '分数' from emp;
data:image/s3,"s3://crabby-images/22771/22771cdf2710827f072e1c8600b181073e43d8ef" alt=""
求学生表中学生姓名占用的字节数:
因为这里的字符集编码为utf8,utf8中一个汉字占三个字节的大小, 在文段中,name都是两个文字,所以输出的都是6。
sql
select length(name) ,name from emp;
data:image/s3,"s3://crabby-images/e65b9/e65b9331725a1e127f5ecbcbc1d9b00ce777a0d4" alt=""
2.2 字符串修改显示
将emp表中所有名字中有 三 的替换成 山:
sql
select replace(name,'三','山'),name from emp;
data:image/s3,"s3://crabby-images/9d30c/9d30c084213bee79cd9b590c33c3f0a586e521a4" alt=""
截取emp表中name字段的第二个到第三个字符:
SUBSTRING 函数用于从一个字符串中提取子字符串。
sql
SUBSTRING(str, pos, len)
str:需要提取子字符串的原始字符串。
pos:开始提取的位置(基于1的索引)。
len:可选参数,表示要提取的字符数。如果省略,将返回从pos开始到字符串末尾的所有字符。
** 另一种形式:**
sql
SUBSTRING(str FROM pos FOR len)
FROM pos:指定开始提取的位置。
FOR len:指定要提取的字符数。
sql
select substring(name,1,1),name from emp;
data:image/s3,"s3://crabby-images/14fe4/14fe4d0ca3f69c5d0424c20824e4d17e237a7cec" alt=""
** 以上对字符串的修改都不会影响到原来的字段信息,只是改变了显示的字符串,若想要更改字段中的字符串,请进行CURD操作。**
data:image/s3,"s3://crabby-images/abeee/abeee11b1fff8aabbc5d1430122f4c5d7bc742b6" alt=""
以首字母小写的方式显示所有学生的姓名:
LCASE(或LOWER)函数用于将字符串转换为小写。这个函数在处理大小写不敏感的查询或格式化输出时非常有用。
sql
LCASE(str)
或:
sql
LOWER(str)
其中 str 是要转换为小写的字符串
sql
select concat(lcase(substring(name,1,1)),substring(name,2)) from emp;
data:image/s3,"s3://crabby-images/6f788/6f78895992b30a9fe969e7f5b95bcf156102ac1d" alt=""
data:image/s3,"s3://crabby-images/76d62/76d626d18f72f93e3436fe1667a7b304bdeb8a4f" alt=""
data:image/s3,"s3://crabby-images/4f90d/4f90dfb83a74252211d59f087a8fe9e0b80277ea" alt=""
3. 数学函数
MySQL 提供了丰富的数学函数,用于在查询中执行各种数学运算。以下是一些常用的 MySQL 数学函数及其描述:
函数名称 | 描述 |
---|---|
abs (number) | 绝对值函数 |
bin(decimal number) | 十进制转换二进制 |
hex(decimalNumber) | 转换成十六进制 |
conv(number,from base,to base) | 进制转换 |
ceiling(number) | 向上去整 |
floor (number) | 向下去整 |
format (number,decimal places) | 格式化,保留小数位数 |
hex(decimalNumber) | 转换成十六进制 |
rand() | 返回随机浮点数,范围[0.0,1.0) |
mod(number,denominator) | 取模,求余 |
绝对值:
sql
select abs(-32.4);
data:image/s3,"s3://crabby-images/c3578/c35782a2fc2f28f975896b429beaae8564a3805c" alt=""
向上取整:
sql
select ceiling(54.3);
data:image/s3,"s3://crabby-images/b0ab9/b0ab96f2e833dbd2795c371597259abc12e6b15b" alt=""
向下取整:
sql
select floor(54.3);
data:image/s3,"s3://crabby-images/3a8bc/3a8bc3a6a33111337fc84730f09bb7c25632bfdf" alt=""
保留2位小数位数(小数四舍五入):
sql
select format(12.34567,3);
data:image/s3,"s3://crabby-images/8c804/8c804080d543dc507d21820aa157303408691913" alt=""
产生随机数:
sql
select rand();
data:image/s3,"s3://crabby-images/26f92/26f92058feb33c7d0164471f849d14c1528e4bd2" alt=""
4. 聚合函数
MySQL 提供了多种聚合函数,用于对一组值执行计算并返回单个值。这些函数在数据分析和报告生成中特别有用,因为它们允许你快速总结大量数据。以下是一些常用的 MySQL 聚合函数及其描述:
函数 | 说明 |
---|---|
COUNT([DISTINCT] expr) | 返回查询到的数据的 数量 |
SUM([DISTINCT] expr) | 返回查询到的数据的 总和,不是数字没有意义 |
AVG([DISTINCT] expr) | 返回查询到的数据的 平均值,不是数字没有意义 |
MAX([DISTINCT] expr) | 返回查询到的数据的 最大值,不是数字没有意义 |
MIN([DISTINCT] expr) | 返回查询到的数据的 最小值,不是数字没有意义 |
统计学生的个数:
sql
select count(name) from emp;
data:image/s3,"s3://crabby-images/f5715/f571591f9dcee7ab730d8c527bcdbfd0c12c0fd2" alt=""
统计学生数学成绩的总分:
sql
select sum(math) from emp;
data:image/s3,"s3://crabby-images/a286a/a286ab06a89f22622878968ea27e050b6ad60b0a" alt=""
计算学生的平局成绩:
sql
select avg(chinese+math) 平均分 from emp;
data:image/s3,"s3://crabby-images/6406d/6406dd710d7317775575676f0c3be0262869a8d6" alt=""
打印数学成绩的最高分:
sql
select max(math) from emp;
data:image/s3,"s3://crabby-images/12ecb/12ecbcc4d16c68e207535802b041347e10adac8f" alt=""
5. 其他函数
查询当前用户:
sql
select user();
data:image/s3,"s3://crabby-images/ada5c/ada5c91b3d0baf98182b82d5acd2b90148d55c04" alt=""
md5(str)对一个字符串进行md5摘要,摘要后得到一个32位字符串:
sql
select md5('admin')
data:image/s3,"s3://crabby-images/73b3d/73b3d4e3cf397a738db9beb1987aa14ba3c3e5f8" alt=""
database()显示当前正在使用的数据库:
sql
select database();
data:image/s3,"s3://crabby-images/3dcbb/3dcbb37b47e99bdfc5fc64f64fd9e95100049142" alt=""
password()函数,MySQL数据库使用该函数对用户加密:
sql
select password('root');
data:image/s3,"s3://crabby-images/2aea4/2aea43a4e8e869ebdf54b037ecef6771172698b3" alt=""
ifnull(val1, val2) 如果val1为null,返回val2,否则返回val1的值:
sql
select ifnull('abc', '123');
data:image/s3,"s3://crabby-images/9f349/9f3492ff86530070e2f5bffd9db118633b97317f" alt=""