Mysql学习笔记(9)—— case when

本文详细介绍了MySQL中的CASE WHEN表达式,包括简单CASE和搜索CASE的用法。同时,深入讲解了窗口函数的概念,如RANK、DENSE_RANK和ROW_NUMBER的差异,并给出了在没有PARTITION BY时的排序效果。此外,还探讨了窗口函数在聚合函数如累加和移动平均中的应用,以及如何设置时间范围,如rows between 1 preceding and 1 following。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

case 表达式:简单case表达式,搜索case表达式

简单case表达式:
在这里插入图片描述
case后为条件(可以是列名)
若等于when后面的值,则执行then
都不满足,执行else结果

搜索case表达式(推荐使用)
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
多表联结实现:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

窗口函数(OLAP: online analytical processing):可以做一些排序排名,聚合函数一般无法做到

语法:(partition by可以省略)
RANK
DENSE_RANK
ROW_NUMBER
在这里插入图片描述

需求:对bedroom是分组,并对相同数量的bedrooms的price进行排列
在这里插入图片描述
在这里插入图片描述
省略partition by(相当于少了分组条件):按照price升序排列,类似于一个单独的orderby,只不过多了一个ranking
在这里插入图片描述
RANK:并列,不连续
DENSE_RANK:并列连续
ROW_NUMBER:无并列,顺序排列
在这里插入图片描述
在这里插入图片描述
常用的聚合函数也可作为窗口函数来使用
累加:
在这里插入图片描述
累加之后再求平均:空值不参与做平均
在这里插入图片描述

需求:做三天的移动平均:ABC,BCD……
在这里插入图片描述
row 2 preceding:除本身外可以向前看两行
在这里插入图片描述
除本身外,前看一天,后看一天:rows between 1 preceding and 1 following
在这里插入图片描述
只有following……

黑马程序员的 MySQL 学习笔记涵盖从基础到高级的内容,以下是根据已有资料整理的核心知识点和示例代码。 ### 数据库基础 MySQL 是一种关系型数据库管理系统(RDBMS),它允许用户通过 SQL 语言来管理和操作数据。在安装过程中,可以设置 root 用户的密码,例如 `123456`。启动和停止 MySQL 服务可以通过命令行执行: ```bash # 启动 MySQL 服务 net start mysql80 # 停止 MySQL 服务 net stop mysql80 ``` 客户端连接可以通过 MySQL 自带的命令行工具或者系统自带的命令行工具执行以下指令: ```bash mysql -u root -p ``` ### 数据模型与 DDL 关系型数据库由多张相互连接的二维表组成,这些表具有统一的数据格式,便于维护。数据定义语言(DDL)用于创建、修改和删除数据库对象,如表、索引等。例如,创建一个员工表: ```sql CREATE TABLE emp ( id INT PRIMARY KEY, name VARCHAR(100), salary DECIMAL(10, 2), managerid INT, hire_date DATE ); ``` ### 约束 为了确保数据的正确性、有效性和完整性,可以在字段上添加约束。常见的约束包括非空(NOT NULL)、唯一(UNIQUE)、主键(PRIMARY KEY)、默认值(DEFAULT)、检查(CHECK)和外键(FOREIGN KEY)。例如,为员工表中的工资字段添加非空和默认值约束: ```sql ALTER TABLE emp MODIFY salary DECIMAL(10, 2) NOT NULL DEFAULT 0; ``` ### 查询与子查询 SQL 提供了丰富的查询功能,包括使用函数进行计算和条件判断。例如,要计算某位员工的入职天数,可以使用 `DATEDIFF` 函数;而对分数进行等级划分,则可以使用 `CASE ... WHEN ...` 结构。下面是一个使用子查询的例子,查找与“张无忌”相同薪资和经理ID的所有员工: ```sql SELECT * FROM emp WHERE (salary, managerid) = (SELECT salary, managerid FROM emp WHERE name = '张无忌'); ``` ### 用户权限管理 当遇到错误提示不允许创建带有 GRANT 权限的用户时,首先确认目标用户是否存在,并确保当前登录的用户有足够的权限来授予其他用户。如果需要创建新用户并赋予所有权限,可以按照如下步骤操作: ```sql -- 创建用户 CREATE USER 'new_user'@'host' IDENTIFIED BY 'password'; -- 授予所有权限 GRANT ALL PRIVILEGES ON *.* TO 'new_user'@'host' WITH GRANT OPTION; -- 刷新权限 FLUSH PRIVILEGES; ``` 以上内容展示了黑马程序员关于 MySQL 学习笔记的一部分精华内容,涵盖了基本概念、安装配置、数据模型、约束、查询以及用户权限管理等方面的知识点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值