【MySQL】数据库函数通关教程上篇(聚合、数学、字符串、日期、控制流函数)(下)

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS Agent(兼容OpenClaw),2核4GB
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 文章目录写在前面1 聚合函数1.1 GROUP_CONCAT()1.2 其他聚合函数2 数学函数3 字符串函数4 日期函数4.1 常见日期函数与使用4.2 日期格式5 控制流函数5.1 if逻辑判断语句5.2 case when语句


🖊 示例代码:

Tips: 答案在代码注释里哦~~~

-- 1.获取时间戳
SELECT UNIX_TIMESTAMP();  -- 1653890515
-- 2.将一个日期转化为毫秒值
SELECT UNIX_TIMESTAMP('2022-05-30 14:02:57');  -- 1653890577
-- 3.将时间戳转化为指定格式的日期
SELECT FROM_UNIXTIME(1653890577,'%Y-%m-%d %H-%i-%s');  -- 2022-05-30 14-02-57
-- 4.获取当前年月日
SELECT CURDATE();  -- 2022-05-30
-- 5.获取当前时分秒
SELECT CURRENT_TIME();  -- 14:05:30
-- 6.获取当前时间包括年月日时分秒
SELECT CURRENT_TIMESTAMP();  -- 2022-05-30 14:07:12
-- 7.获取日期之间的差值(天)
SELECT DATEDIFF('2022-05-30','2008-07-23');  -- 5059
-- 8.获取时间差值
SELECT TIMEDIFF('17:00:00','16:00:00');  -- 01:00:00
-- 9.日期格式化
SELECT DATE_FORMAT('2022-6-1 14:16:5','%Y-%m-%d %H-%i-%s');  -- 2022-06-01 14-16-05
-- 10.日期加减
SELECT DATE_ADD('2022-06-01',INTERVAL 1 DAY);  -- 2022-06-02
SELECT DATE_SUB('2022-06-01',INTERVAL 1 DAY);  -- 2022-05-31
-- 11.从日期中获取年、日、月
SELECT EXTRACT(YEAR FROM '2022-06-01');  -- 2022
SELECT EXTRACT(DAY FROM '2022-06-01');  -- 1
SELECT EXTRACT(MONTH FROM '2022-06-01');  -- 6

4.2 日期格式

🐍 日期格式附表:

格式 描述
%a 缩写星期名
%b 缩写月名
%c 月,数值
%D 带有英文前缀的月中的天
%d 月的天,数值(00-31)
%e 月的天,数值(0-31)
%f 微秒
%H 小时(00-23)
%h 小时(01-12)
%I 小时(01-12)
%i 分钟,数值(00-59)
%j 年的天(001-366)
%k 小时(0-23)
%l 小时(1-12)
%M 月名
%m 月,数值(00-12)
%p AM 或 PM
%r 时间,12-小时(hh:mm:ss AM 或 PM)
%S 秒(00-59)
%s 秒(00-59)
%T 时间, 24-小时(hh:mm:ss)
%U 周(00-53)星期日是一周的第一天
%u 周(00-53)星期一是一周的第一天
%V 周(01-53)星期日是一周的第一天,与 %X 使用
%v 周(01-53)星期一是一周的第一天,与 %x 使用
%W 星期名
%w 周的天(0=星期日, 6=星期六)
%X 年,其中的星期日是周的第一天,4 位,与 %V 使用
%x 年,其中的星期一是周的第一天,4 位,与 %v 使用
%Y 年,4 位
%y 年,2 位

5 控制流函数

5.1 if逻辑判断语句

格式 说明
IF(expr,v1,v2) 如果表达式 expr 成立,返回 v1,否则返回 v2
IFNULL(v1,v2) v1如果为 NULL 则返回 v1,否则返回 v2
ISNULL(expr) 判断表达式是否为 NULL,是就返回 1,反之为0
NULLIF(s1,s2) 比较字符串,如果 s1 与 s2 相等,就返回 NULL,否则返回 s1

案例1️⃣: 查询判断成绩是否优秀

 首先先准备下面的数据表,具体数据如图,数据表结构代码如下:

CREATE TABLE IF NOT EXISTS student(
    name VARCHAR(20),
    score INT
);
INSERT INTO student VALUES ('祢豆子', 95);
INSERT INTO student VALUES ('漩涡鸣人', 85);
INSERT INTO student VALUES ('佐助', 75);
INSERT INTO student VALUES ('路飞', 55);
INSERT INTO student VALUES ('乔巴', 45);


下面使用逻辑判断语句进行确定是否优秀,并查询,参考代码及结果如下:

SELECT *, IF(score >= 85, '优秀', '不优秀') 'grade'
FROM student;


这里我们仅仅将成绩分成了两类:优秀与不优秀。可是实际情况是成绩分为良好、及格与不及格,但是 if 逻辑判断语句却不能很好的解决,那我们究竟该如何操作才能将成绩分成3类呢? 我们引入 case when 语句。


5.2 case when语句

🍌 语法格式:

CASE expression
  WHEN condition1 THEN result1
  WHEN condition2 THEN result2
  ...
  WHEN conditionN THEN resultN
  ELSE result
END

📖 说明:


 CASE 表示函数的开始,END 表示函数的结束,如果 condition1 成立,则返回 result1,以此类推… … 如果都不成立,则返回 ELSE 后的 result。


案例2️⃣: 将成绩分为良好、及格与不及格三类


 我们还是使用案例1的数据表,并通过 case when函数来实现:

SELECT *,
       CASE score
           WHEN score >= 85 THEN '良好'
           WHEN score >= 60 THEN '及格'
           ELSE '不及格'
           END AS 'grade'
FROM student;

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
8月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
537 158
|
8月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
8月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1424 152
|
8月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
1033 156
|
8月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
578 156
|
8月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
689 161
|
8月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
8月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
8月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
8月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
973 7

推荐镜像

更多