mysql开窗函数使用
时间: 2024-02-01 10:04:03 浏览: 104
在MySQL中,窗口函数的使用与版本有关。在8.0版本之后,才支持使用窗口函数。窗口函数和分组(group by)的区别在于窗口函数保持原来的记录数,而group by分组统计聚合后的记录数。窗口函数具有同时具有分组和排序的功能,并且不会减少原表的行数。窗口函数的语法如下:
<窗口函数> over (partition by <用于分组的列名> order by <用于排序的列名>)。
MySQL支持多种窗口函数,根据功能的不同可以分为序号函数、分布函数、前后函数、头尾函数和其他函数。其中,排序开窗函数包括row_number(行号)、rank(排名)、dense_rank(密集排名)和ntile(分组排名)。聚合开窗函数可以使用sum、count、avg等聚合函数配合over子句来实现对分组的聚合操作。例如,在使用SUM函数时,可以使用over子句指定分组和排序的列名,来计算每个分组的聚合结果。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [MySql数据库高级函数—窗口函数(开窗函数)](https://blog.csdn.net/qq_39754641/article/details/130586238)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"]
- *2* [MySQL:开窗函数](https://blog.csdn.net/weixin_48719464/article/details/130197380)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"]
- *3* [MySQL开窗函数](https://blog.csdn.net/mr__sun__/article/details/124257213)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"]
[ .reference_list ]
阅读全文