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覆盖和重写的区别及说明

《JAVA覆盖和重写的区别及说明》非静态方法的覆盖即重写,具有多态性;静态方法无法被覆盖,但可被重写(仅通过类名调用),二者区别在于绑定时机与引用类型关联性... 目录Java覆盖和重写的区别经常听到两种话认真读完上面两份代码JAVA覆盖和重写的区别经常听到两种话1.覆盖=重写。2.静态方法可andro

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

MyBatis中$与#的区别解析

《MyBatis中$与#的区别解析》文章浏览阅读314次,点赞4次,收藏6次。MyBatis使用#{}作为参数占位符时,会创建预处理语句(PreparedStatement),并将参数值作为预处理语句... 目录一、介绍二、sql注入风险实例一、介绍#(井号):MyBATis使用#{}作为参数占位符时,会

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

C++中NULL与nullptr的区别小结

《C++中NULL与nullptr的区别小结》本文介绍了C++编程中NULL与nullptr的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编... 目录C++98空值——NULLC++11空值——nullptr区别对比示例 C++98空值——NUL