当前位置:网站首页>MySQL窗口函数 PARTITION BY()函数介绍
MySQL窗口函数 PARTITION BY()函数介绍
2022-08-03 16:02:00 【飞Link】
前期数据准备
# 创建数据库
create database if not exists shopping charset utf8;
# 选择数据库
use shopping;
# 创建产品表
create table product
(
id int primary key,
name varchar(20),
price int,
type varchar(20),
address varchar(20)
);
# 插入产品数据
insert into shopping.product(id, name, price, type, address) values
(1,'商品1',200,'type1','北京'),
(2,'商品2',400,'type2','上海'),
(3,'商品3',600,'type3','深圳'),
(4,'商品4',800,'type1','南京'),
(5,'商品5',1000,'type2','成都'),
(6,'商品6',1200,'type3','武汉'),
(7,'商品7',1400,'type1','黑龙江'),
(8,'商品8',1600,'type2','黑河'),
(9,'商品9',1800,'type3','贵州'),
(10,'商品10',2000,'type1','南宁');
一、PARTITION BY与GROUP BY区别
一、函数类型
group by 是分组函数,partition by是分析函数
二、执行顺序
from > where > group by > having > order,而partition by应用在以上关键字之后,可以简单理解为就是在执行完select之后,在所得结果集之上进行partition by分组
二、查询结果
partition by 相比较于group by,能够在保留全部数据的基础上,只对其某些字段做分组排序,而group by则保留参与分组的字段和聚合函数的结果,类似excel中的透视表
二、PARTITION BY的基本用法
在OVER()中添加PARTITION BY
# 查询每种商品的id,name,同类型商品数量
select id,name,count(*) over (partition by type) from product;
PARTITION BY传入多列
# 查询每个城市每个类型价格最高的商品名称
select
name,
price,
type,
max(price) over (partition by address,type) as 'max_price'
from product;
边栏推荐
猜你喜欢
#夏日挑战赛# HarmonyOS 实现一个绘画板
一文看懂推荐系统:概要02:推荐系统的链路,从召回粗排,到精排,到重排,最终推荐展示给用户
我在滴滴做开源
DataGrip数据仓库工具
详谈RDMA技术原理和三种实现方式
Yii2安装遇到Loading composer repositories with package information
【Unity入门计划】基本概念(8)-瓦片地图 TileMap 01
Introduction to the advantages of the new generation mesh network protocol T-Mesh wireless communication technology
[Code Hoof Set Novice Village 600 Questions] Define a function as a macro
ReentrantLock详解
随机推荐
《安富莱嵌入式周报》第276期:2022.07.25--2022.07.31
leetcode: 899. Ordered Queue [Thinking Question]
GTK实现旋转加载动画
CopyOnWriteArrayList details
在 360 度绩效评估中应该问的 20 个问题
Neural networks, cool?
socket快速理解
2021年数据泄露成本报告解读
瞌睡检测系统介绍
常见分布式理论(CAP、BASE)和一致性协议(Gosssip、Raft)
元宇宙系列--Value creation in the metaverse
AI也有健忘症?英国41岁教授专访:解决灾难性遗忘
unity用代码生成LightProbeGroup
袁小林:沃尔沃专注于出行的安全感,并且把它做到极致
罗克韦尔AB PLC RSLogix5000中创建新项目、任务、程序和例程的具体方法和步骤
MATLAB | 七夕节快到了,还不给朋友安排上这个咕呱小青蛙?
STM32的HAL和LL库区别和性能对比
【翻译】关于扩容一个百万级别用户系统的六个课程
参与便有奖,《新程序员》杂志福利来袭!
详谈RDMA技术原理和三种实现方式