一:oracle实现去重:mysql
user数据表:sql
分两步:1.查询重复数据 2.删除重复数据数据库
1.查询重复数据:
在oracle中实现查询重复数据,能够借助于rowid这个伪列。oracle中每一个表物理上都存在一个rowid的列,这个列
是每行数据在oracle中惟一标识,每一个表的主键能够保证数据在本表中不重复,rowid能够保证该条数据在数据库
中的全部表中都不重复。oracle
--查询重复数据 用户名和密码都相同的数据叫重复数据 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加上,去重重复数据,只要用户名相同,就认为这条数据重复了。code
delete from users u1 where exists ( select 1 from users u2 where u1.username=u2.username and u1.id>u2.id);
二:oracle实现分页blog
mysql中怎么实现分页,使用limit m,n m从第几条数据开始取,下标从0开始。n表明最多取多少条数据。
在oracle中不能再使用limit进行分页。能够使用rownum来进行分页。和rowid差很少,rownum也是一个伪列,
rowid是物理上存在的一个伪列,rownum是物理上不存在的。只在查询的时候赋值。用的时候和rowid差很少。it
举例:
查询前5条数据:
select * from emp where rownum <6;
查询第6到第10条数据:(错误的)
select * from emp where rownum>5 and rownum<11;
执行直接sql语句,查询不出结果,是由于rownum若是使用大于号查询不到数据:class
rownum是先查询再赋值。若是查询返回的数据知足条件就获取一个rownum赋值,rownum从1开始赋值,接着 2 3 4 5 6select
解决方法:sql语句
经过子查询把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;