当前位置: 首页 > news >正文

mfy学习笔记

创建表并导入数据

CREATE TABLE sales (id INT,salesperson STRING,region STRING,sales_amount INT,sale_date DATE
);INSERT INTO sales (id, salesperson, region, sales_amount, sale_date)
VALUES
(1, 'Alice', 'North', 1000, '2023-01-01'),
(2, 'Bob', 'South', 1500, '2023-01-02'),
(3, 'Alice', 'North', 2000, '2023-01-03'),
(4, 'Charlie', 'East', 1200, '2023-01-04'),
(5, 'Bob', 'South', 1800, '2023-01-05'),
(6, 'Alice', 'North', 2500, '2023-01-06'),
(7, 'Charlie', 'East', 1300, '2023-01-07'),
(8, 'Bob', 'South', 2200, '2023-01-08'),
(9, 'Alice', 'North', 3000, '2023-01-09'),
(10, 'Charlie', 'East', 1400, '2023-01-10');

示例数据表:sales

idsalespersonregionsales_amountsale_date
1AliceNorth10002023-01-01
2BobSouth15002023-01-02
3AliceNorth20002023-01-03
4CharlieEast12002023-01-04
5BobSouth18002023-01-05
6AliceNorth25002023-01-06
7CharlieEast13002023-01-07
8BobSouth22002023-01-08
9AliceNorth30002023-01-09
10CharlieEast14002023-01-10
---### 1. `CASE WHEN` 示例
根据销售额给销售人员分类:```sql
SELECT salesperson,sales_amount,CASE WHEN sales_amount < 1500 THEN 'Low'WHEN sales_amount BETWEEN 1500 AND 2500 THEN 'Medium'ELSE 'High'END AS sales_category
FROM sales;
运行结果:
salespersonsales_amountsales_category
Alice1000Low
Bob1500Medium
Alice2000Medium
Charlie1200Low
Bob1800Medium
Alice2500Medium
Charlie1300Low
Bob2200Medium
Alice3000High
Charlie1400Low

2. SUM(CASE WHEN) 示例

计算每个区域的销售总额:

SELECT region,SUM(CASE WHEN salesperson = 'Alice' THEN sales_amount ELSE 0 END) AS alice_sales,SUM(CASE WHEN salesperson = 'Bob' THEN sales_amount ELSE 0 END) AS bob_sales,SUM(CASE WHEN salesperson = 'Charlie' THEN sales_amount ELSE 0 END) AS charlie_sales
FROM sales
GROUP BY region;
运行结果:
regionalice_salesbob_salescharlie_sales
North850000
South055000
East003900

3. RANK() 示例

根据销售额对销售人员进行排名:

SELECT salesperson,sales_amount,RANK() OVER (ORDER BY sales_amount DESC) AS sales_rank
FROM sales;
运行结果:
salespersonsales_amountsales_rank
Alice30001
Bob22002
Alice25003
Bob18004
Alice20005
Bob15006
Charlie14007
Charlie13008
Alice10009
Charlie120010

4. ROW_NUMBER() 示例

为每个销售人员的销售额分配一个唯一的行号:

SELECT salesperson,sales_amount,ROW_NUMBER() OVER (PARTITION BY salesperson ORDER BY sales_amount DESC) AS row_num
FROM sales;
运行结果:
salespersonsales_amountrow_num
Alice30001
Alice25002
Alice20003
Alice10004
Bob22001
Bob18002
Bob15003
Charlie14001
Charlie13002
Charlie12003

5. DENSE_RANK() 示例

根据销售额对销售人员进行密集排名(不会跳过排名):

SELECT salesperson,sales_amount,DENSE_RANK() OVER (ORDER BY sales_amount DESC) AS dense_rank
FROM sales;
运行结果:
salespersonsales_amountdense_rank
Alice30001
Bob22002
Alice25003
Bob18004
Alice20005
Bob15006
Charlie14007
Charlie13008
Alice10009
Charlie120010

总结

  • CASE WHEN:用于条件判断,生成新的列。
  • SUM(CASE WHEN):用于按条件汇总数据。
  • RANK():用于排名,允许并列排名并跳过后续名次。
  • ROW_NUMBER():用于生成唯一的行号,即使数据相同也会分配不同行号。
  • DENSE_RANK():用于密集排名,允许并列排名但不跳过后续名次。

通过这些示例和运行结果,可以清晰地展示每个函数的作用和用法!

http://www.lryc.cn/news/543277.html

相关文章:

  • C语言--文件操作
  • 网络安全内参
  • C++大整数类的设计与实现
  • 在 macOS 系统上安装 kubectl
  • 【人工智能】蓝耘智算平台盛大发布DeepSeek满血版:开创AI推理体验新纪元
  • 构建数据治理闭环:DAMA视角下的全流程实践与价值变现
  • 《深度剖析:AI与姿态估计技术在元宇宙VR交互中的应用困境》
  • 【Python LeetCode】面试经典 150 题
  • 2011-2019年各省乡镇综合文化站机构数数据
  • LeetCode 热题100 226. 翻转二叉树
  • mysql 拼接多行合并为一行
  • 【Java项目】基于Spring Boot的论坛管理系统
  • unity学习54:图片+精灵+遮罩mask,旧版文本 text 和新的TMP文本
  • 2024年国赛高教杯数学建模D题反潜航空深弹命中概率问题解题全过程文档及程序
  • 什么是数字人
  • 15.5 基于 RetrievalQA 的销售话术增强系统实战:构建智能销售大脑
  • 软件供应链安全工具链研究系列—RASP自适应威胁免疫平台(下篇)
  • WordPress网站502错误全面排查与解决指南
  • PCL源码分析:曲面法向量采样
  • HTTP 动态报错码的原因和解决方法
  • 1分钟用DeepSeek编写一个PDF转Word软件
  • 生成对抗网络(GAN)
  • openlayers结合turf geojson面获取面积和中心点
  • 【SRC实战】修改金币数量实现财富自由
  • 地理数据可视化:飞线说明(笔记)
  • 2024最新版鸿蒙纯血原生应用开发教程文档丨学习ArkTS语言-基本语法
  • 微信小程序-二维码绘制
  • 轻量化网络设计|ShuffleNet:深度学习中的轻量化革命
  • 一天记20个忘10个之五:land
  • Python 类(创建和使用类)