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

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

相关推荐
无响应de神1 小时前
三、用户与权限管理
数据库·mysql
麦聪聊数据19 小时前
数据服务化时代:企业数据能力输出的核心路径
数据库
王小王-12319 小时前
基于 Hive 的网易云音乐数据分析及可视化系统
hive·hadoop·数据分析·音乐数据分析·网易云音乐分析·hive音乐分析·hadoop网易云
shushangyun_19 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡19 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧20 小时前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon20 小时前
SQL学习指南——视图
数据库·sql
活宝小娜20 小时前
mysql详细安装教程
数据库·mysql·adb
贤时间20 小时前
codex 助力oracle ebs 开发
数据库·oracle
秉承初心20 小时前
PostgreSQL 数据性能瓶颈突破实战
数据库·postgresql·oracle