彩票走势图

Navicat使用教程:按组列出的前N个查询

翻译|使用教程|编辑:吴园园|2020-05-18 17:14:06.930|阅读 523 次

概述:前N个查询是按降序获取按值排序的前几条记录的查询。在今天的文章中,我们将确切学习如何按组构造Top N查询。

# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>

相关链接:

Navicat Premium是一个可连接多种数据库的管理工具,它可以让你以单一程序同时连接到MySQL、Oracle及PostgreSQL数据库,让管理不同类型的数据库更加的方便。

点击下载Navicat Premium最新试用版

前N个查询是按降序获取按值排序的前几条记录的查询。通常,这些是使用TOP或LIMIT子句完成的。问题是,前N个结果集被限制为表格中的最高值,而没有任何分组。GROUP BY子句可以帮助解决这个问题,但仅限于每个组的单项最高结果。如果您想要每个类别的前5名,GROUP BY本身将无济于事。这并不意味着它无法完成。实际上,在今天的博客中,我们将确切学习如何按组构造Top N查询。

前N个查询基础知识

为了更好地理解“前N个查询”,让我们组成一个,从中选择运行时间最长的前5个电影。如果您不熟悉Sakila数据库,则它是一个MySQL数据库,其中包含许多与虚构的视频租赁商店有关的表,视图和查询。表格包括演员,电影,顾客,租金等。

按类别分组结果

GROUP BY子句将聚合函数应用于一个或多个字段,以便数据与您指定的分组相关。就分组结果而言,这是向前迈出的一步,但是GROUP BY仍然有两个限制:

它仅提供每个组的第一个结果(即行),而忽略其他结果,

这些列仅限于分组条件和汇总字段中包含的列。所有其他列均不可访问。

此查询使用GROUP BY来显示每个评级的最长播放电影:

Navicat使用教程:按组列出的前N个查询

请注意,我们不能包含电影标题,因为它既不是GROUP BY也不是聚合字段的一部分。

Windows函数速成课程

Windows函数中的术语“窗口”是指函数在其上运行的行的集合,因为函数使用窗口中行的值来计算返回的值。窗口内的行集被汇总为一个值。

要在查询中使用窗口函数,必须使用OVER()子句定义窗口。它做两件事:

  1. 通过PARTITION BY子句定义窗口分区以形成行组。
  2. 通过ORDER BY子句对分区中的行进行排序。

一个查询可以包括具有相同或不同窗口定义的多个窗口函数。

我们的查询使用ROW_NUMBER()窗口函数。它为查询的内部窗口结果集中的每一行分配一个连续的整数。我们可以使用该值将每个评级的结果限制在前5名。这是通过将长度按降序排列来完成的。



结论

在今天的文章中,我们学习了如何构造一个查询,以获取Navicat Premium中每个类别的前5行。第15版增加了100多个增强功能,其中包括几个新功能,可为您提供比以往更多的构建,管理和维护数据库的方式!有想要购买正版授权的朋友,欢迎


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn

文章转载自:

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP