zoukankan      html  css  js  c++  java
  • 复习巩固:oracle如何实现去重和分页

    一: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;
  • 相关阅读:
    bzoj 4010: [HNOI2015]菜肴制作
    bzoj4827: [Hnoi2017]礼物
    bzoj3160: 万径人踪灭
    bzoj4503: 两个串
    bzoj2648: SJY摆棋子
    bzoj2780: [Spoj]8093 Sevenk Love Oimaster
    bzoj3926: [Zjoi2015]诸神眷顾的幻想乡
    MySQL:记录的增删改查、单表查询、约束条件、多表查询、连表、子查询、pymysql模块、MySQL内置功能
    MySQL数据库:SQL语句基础、库操作、表操作、数据类型、约束条件、表之间的关系
    网络编程进阶:并发编程之协程、IO模型
  • 原文地址:https://www.cnblogs.com/qianjinyan/p/11349045.html
Copyright © 2011-2022 走看看