Heim > Datenbank > MySQL-Tutorial > Hauptteil

MySQL PARTITION BY 子句

WBOY
Freigeben: 2023-08-29 21:25:02
nach vorne
1474 人浏览过

MySQL PARTITION BY 子句

Partition By 子句可用于提高查询性能。它降低了存储需求,并提高了数据可管理性。通过对大表进行分区,可以更快地执行仅访问一小部分数据的查询。分区还可以缩短备份和恢复时间。在本文中,我们将通过语法和各种示例讨论 MySQL 中的 Partition By 子句。

简介

PARTITION BY 子句的目的是将表的行分组到单独的分区中。当使用同一分区中的其他行对分区内的特定行执行计算时,这特别有用。

PARTITION BY 子句必须始终在 OVER() 子句中使用。 PARTITION BY 子句创建的分区也称为窗口。该子句专门对 RANK()、LEAD() 和 LAG() 等窗口函数进行操作。

如果从 OVER() 子句中排除 PARTITION BY 子句,则整个表将被视为单个分区。

语法

Window_function ( expression )
   Over ( partition by expr [order_clause] [frame_clause] )
Nach dem Login kopieren

order_clause 和frame_clause 是语法的可选组件。

在 MySQL 中,Partition 子句中的表达式可以是列名,也可以是内置函数。但是,在标准 SQL 中,表达式中只允许使用列名称。

示例

让我们以“Hacker”表为例 -

h_id

h_name

challenge_id

分数

3

拉朱

111

20

2

密斯莱什

111

80

5

楼陀罗

112

40

5

莫汉

114

90

4

洛汗

112

30

1

索汉

112

40

我们需要确定每个挑战中每个黑客的排名。换句话说,我们必须列出所有参与挑战的黑客以及他们在该挑战中各自的排名。

为了实现此目的,我们使用以下查询:

select challenge_id, h_id, h_name, score,
dense_rank() over ( partition by challenge_id order by score desc )
as "rank", from hacker;
Nach dem Login kopieren

在此查询中,partition by 子句按challenge_id 对表进行分组。

order by 子句按照得分降序对每个分区中的黑客进行排序。

over() 子句指定如何对窗口函数rank() 的表行进行分区和排序。

窗口函数dense_rank()为挑战的有序分区中的每个黑客分配一个等级。如果两个黑客得分相同,则他们被分配相同的排名。

结果输出显示所有黑客的列表以及他们在每个挑战中各自的排名 -

challenge_id

h_id

h_name

分数

排名

111

2

密斯莱什

80

1

111

3

拉朱

20

2

112

楼陀罗

40

1

112

1

索汉

40

1

112

4

洛汗

30

2

114

5

莫汉

90

1

因此,我们成功获得了所有黑客的列表以及他们在每个单独挑战中的排名。

PARTITION BY 子句的使用

  • 将表的行分组到单独的分区中,以便对分区内的特定行执行计算。

  • 降低存储要求并提高数据可管理性。

  • 通过更快地执行仅访问一小部分数据的查询来提高查询性能。

  • 缩短备份和恢复时间。

结论

MySQL 中的 PARTITION BY 子句是一个有用的工具,用于将表的行分组到单独的分区中,从而提高查询性能并减少存储需求。该子句专门对 RANK()、LEAD() 和 LAG() 等窗口函数进行操作。语法很简单,并且允许子句中使用的表达式类型具有灵活性。上面的示例演示了 PARTITION BY 子句在计算每个客户的销售总额时的功能。通过利用这一强大的功能,用户可以优化数据库性能并提高数据可管理性。

以上是MySQL PARTITION BY 子句的详细内容。更多信息请关注PHP中文网其他相关文章!

Quelle:tutorialspoint.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!