一:oracle实现去重:

user数据表:

分两步:1.查询重复数据  2.删除重复数据

1.查询重复数据:
在oracle中实现查询重复数据,可以借助于rowid这个伪列。oracle中每个表物理上都存在一个rowid的列,这个列
是每行数据在oracle中唯一标识,每个表的主键可以保证数据在本表中不重复,rowid可以保证该条数据在数据库
中的所有表中都不重复。

 --查询重复数据 用户名和密码都相同的数据叫重复数据
select u1.*,rowid from users u1 where exists ( select 1
from users u2 where u1.username=u2.username and u1.password=u2.password and u1.rowid>u2.rowid );
--删除重复数据
delete from users u1 where exists ( select 1 from users u2 where u1.username=u2.username and
u1.password=u2.password and u1.rowid>u2.rowid );

例:把用户表的主键id加上,去重重复数据,只要用户名相同,就认为这条数据重复了。

delete from users u1 where exists ( select 1 from users u2 where u1.username=u2.username and
u1.id>u2.id);

二:oracle实现分页

mysql中怎么实现分页,使用limit m,n m从第几条数据开始取,下标从0开始。n代表最多取多少条数据。
在oracle中不能再使用limit进行分页。可以使用rownum来进行分页。和rowid差不多,rownum也是一个伪列,
rowid是物理上存在的一个伪列,rownum是物理上不存在的。只在查询的时候赋值。用的时候和rowid差不多。

举例:
查询前5条数据:
select * from emp where rownum <6;
查询第6到第10条数据:(错误的)
select * from emp where rownum>5 and rownum<11;
执行直接sql语句,查询不出结果,是因为rownum如果使用大于号查询不到数据:

rownum是先查询再赋值。如果查询返回的数据满足条件就获取一个rownum赋值,rownum从1开始赋值,接着 2 3 4 5 6

解决方法:

通过子查询把rownum从伪列变成实际的列。

select * from (select e.*,rownum r from emp e where rownum<11) where r>5

对emp表按empno倒序排列,获取从第6到第10条数据。

select * from ( select e.*,rownum r from ( select * from emp order by empno desc)e where rownum<11 )
where r>5;

最新文章

  1. 關於imagick不得不說的一些事
  2. Redis设计与实现-附加功能
  3. 如何把bootstrap用webpack打包
  4. php strpos 用法实例教程
  5. hash --C++
  6. HDU-4699 Editor 数据结构维护
  7. Flask学习记录之Flask-Mail
  8. X-factor Chains(POJ3421 素数)
  9. SSD常见问题的技术分析
  10. 记录break和continue的区别
  11. C++虚函数表调用学习
  12. python计算斐波那契数列
  13. 数据可视化的开源方案: Superset vs Redash vs Metabase (一)
  14. [物理学与PDEs]第4章第2节 反应流体力学方程组 2.4 反应流体力学方程组的数学结构
  15. 第四章Android移植环境搭建
  16. JS的作用域链与原型链
  17. Python成绩雷达图
  18. [luogu3978][bzoj4001][TJOI2005]概率论【基尔霍夫矩阵+卡特兰数】
  19. 【转】 cJSON 源码解析
  20. php和NodeJs共存的开发环境

热门文章

  1. EasyNVR摄像机网页直播中,推流组件EasyRTMP推送RTMP扩展支持HEVC(H.265)的方案
  2. 如何杀死处于进程状态D的进程
  3. react-redux源码学习
  4. [Python]MySQLdb for Python使用指南/Python的数据库操作
  5. 简单的python爬虫教程:批量爬取图片
  6. Linux基础系统优化(二)
  7. docker 部署 nsq
  8. Android--ScrollView边界回弹效果
  9. Feign 失败降级未生效和超时配置优先级问题
  10. tkinter python(图形开发界面) 转自:渔单渠