oracle rownum分页出现重复数据

oracle rownum分页出现重复数据的情况:

一般情况是分组的字段不唯一导致的

解决办法:

原始sql:(错误的)

复制代码
SELECT *
 FROM (
 SELECT a.*, ROWNUM r
 FROM hospital_inpatient_medication a
 WHERE  TO_CHAR(discharge_date,'YYYY-MM-DD HH24:MI:SS') BETWEEN '2024-01-01 00:00:00' AND '2024-02-01 00:00:00'
 AND  ROWNUM <= 500
 ORDER BY discharge_date asc 
)
WHERE r >= 1

改进:(正确的)

复制代码
select *
from (
select row_.*, rownum rownum_
from ( select * from hospital_inpatient_medication
WHERE TO_CHAR(discharge_date,'YYYY-MM-DD HH24:MI:SS') BETWEEN '2024-02-01 00:00:00' AND '2024-03-01 00:00:00'
order by discharge_date asc, id asc )
row_ where rownum <= 5000) b
where b.rownum_ >=1

思路:就是加个唯一键分组

相关推荐
DarkAthena3 分钟前
【GaussDB】用AI解析UGO中的SQL审核模块的实现
数据库·sql·gaussdb
xdpcxq102910 分钟前
MySQL 5.6 2000 万行高频读写表新增字段
数据库·mysql
huohuopro11 分钟前
Redis安装和杂谈
数据库·redis·缓存
马猴烧酒.22 分钟前
【团队空间|第十一天】基础功能实现,RBAC权限控制,ShardingSphere详解
java·开发语言·数据库
long31626 分钟前
KMP模式搜索算法
数据库·算法
西伯利亚疯狂的蚯蚓28 分钟前
数据分析参考步骤及分析报告简例
数据分析·智能商业
有味道的男人28 分钟前
接入MIC(中国制造)接口的帮助
网络·数据库·制造
Jacob程序员31 分钟前
达梦数据库私有服务配置指南
linux·服务器·数据库
isNotNullX32 分钟前
数据分析没思路?5 个核心流程帮你理清所有步骤
数据库·数据挖掘·数据分析
OceanBase数据库官方博客34 分钟前
高德刘振飞:从自研 OceanBase,回望数据库技术范式变迁
数据库·oceanbase·分布式数据库·高德