rank,dense_rank,row_number,ntile区别和用法。

2023-12-11 10:48

本文主要是介绍rank,dense_rank,row_number,ntile区别和用法。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景,忙完了。终于不用再赶了,自己在做项目中遇到的和当时迷惑的某些点,记录了一下,现在来做一个总结。
RANK() 排序相同时会重复,总数不会变。
DENSE_RANK()排序相同时会重复,总数会减少。 (dense:稠密的意思)

1建表
create table product_sell (
big_class string,
small_class string,
money double
) partitioned by (da string)
2插入数据
insert into product_sell partition (da=“201907”)
values
(“彩电”, “L55E5800A-UD”, 80),
(“彩电”, “L55V6500A-3D”, 90),
(“彩电”, “LSC550FN11-C”, 100),
(“冰箱”, “BCD-520WBEPF2”, 80),
(“冰箱”, “BCD-435WBEPIZ50”, 90),
(“冰箱”, “BCD-202U16”, 100),
(“空调”, “KFRd-35G/E012BpA”, 90),
(“空调”, “KFRd-26GW/DBp-XP21”, 100),
(“空调”, “KFR-35W/S13”, 100);
3.测试
3.1 RANK
查询本月个品类各型号销售额
select *, rank() over (partition by big_class order by money desc) from product_sell where da=“201907”;
在这里插入图片描述
分析看看:空调先并列第一,但没有第二直接到第三了。这个排序不太符合平常的查看习惯。如果出现并列最好后面的提到前面就好,这时就可以用dense_rank()
3.2dense_rank()在这里插入图片描述
dense,意思是稠密的,而rank()生成的排名序列中可能有空隙(可能是不连续的)。dense_rank()则是排序稠密的连续的
3.3row_number()
需求改了,

  1. 首先按照销售额排序
  2. 销售额相同的不要并列,而是再小品类排序
    在这里插入图片描述
    3.4 nticle :切片后的属于哪个切片的值
    在这里插入图片描述

4.总结
ntile/rank / dense_rank / row_number的语法都是一样的,都可以进行排序,不同的只是几个特性:
ntile :指的是将数据分几份,返回的份序列号。

  1. rank / dense_rank都考虑了并列的情况,所以序号可能不唯一,rank在出现并列之后会不连续,而dense_rank是连续的
  2. row_number不考虑并列的情况,所以序号是唯一的,并且也不会出现不连续。因此利用这个特性在给表去重和选择主键是可以用此种方法。这个在下面的文章中做介绍。

这篇关于rank,dense_rank,row_number,ntile区别和用法。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/480422

相关文章

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

MyBatis-Flex BaseMapper的接口基本用法小结

《MyBatis-FlexBaseMapper的接口基本用法小结》本文主要介绍了MyBatis-FlexBaseMapper的接口基本用法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具... 目录MyBATis-Flex简单介绍特性基础方法INSERT① insert② insertSelec

java中不同版本JSONObject区别小结

《java中不同版本JSONObject区别小结》本文主要介绍了java中不同版本JSONObject区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录1. FastjsON2. Jackson3. Gson4. org.json6. 总结在Jav

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

数据库使用之union、union all、各种join的用法区别解析

《数据库使用之union、unionall、各种join的用法区别解析》:本文主要介绍SQL中的Union和UnionAll的区别,包括去重与否以及使用时的注意事项,还详细解释了Join关键字,... 目录一、Union 和Union All1、区别:2、注意点:3、具体举例二、Join关键字的区别&php

java中的HashSet与 == 和 equals的区别示例解析

《java中的HashSet与==和equals的区别示例解析》HashSet是Java中基于哈希表实现的集合类,特点包括:元素唯一、无序和可包含null,本文给大家介绍java中的HashSe... 目录什么是HashSetHashSet 的主要特点是HashSet 的常用方法hasSet存储为啥是无序的

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

Python中@classmethod和@staticmethod的区别

《Python中@classmethod和@staticmethod的区别》本文主要介绍了Python中@classmethod和@staticmethod的区别,文中通过示例代码介绍的非常详细,对大... 目录1.@classmethod2.@staticmethod3.例子1.@classmethod