WEB开发网
开发学院数据库Oracle 学习 Oracle过程中几个常见问题的总结 阅读

学习 Oracle过程中几个常见问题的总结

 2007-07-31 12:37:31 来源:WEB开发网   
核心提示: 2、在重复的记录中,可能所有列的内容都相同,学习 Oracle过程中几个常见问题的总结(3),但rowid不会相同,所以只要确定出重复记录中那些具有最大rowid的就可以了

2、在重复的记录中,可能所有列的内容都相同,但rowid不会相同,所以只要确定出重复记录中那些具有最大rowid的就可以了,其余全部删除。

实现方法:

SQL> create table a(bm char(4),mc varchar2(20));
  Table created
  SQL> insert into a values(’1111’,’aaaa’);
  SQL> insert into a values(’1112’,’aaaa’);
  SQL> insert into a values(’1113’,’aaaa’);
  SQL> insert into a values(’1114’,’aaaa’);
  SQL> insert into a select * from a;
  4 rows inserted
  SQL> commit;
  Commit complete
  SQL> select rowid,bm,mc from a;
  ROWID BM MC
  ------------------ ---- --------------------
  AAAIRIAAQAAAAJqAAA 1111 aaaa
  AAAIRIAAQAAAAJqAAB 1112 aaaa
  AAAIRIAAQAAAAJqAAC 1113 aaaa
  AAAIRIAAQAAAAJqAAD 1114 aaaa
  AAAIRIAAQAAAAJqAAE 1111 aaaa
  AAAIRIAAQAAAAJqAAF 1112 aaaa
  AAAIRIAAQAAAAJqAAG 1113 aaaa
  AAAIRIAAQAAAAJqAAH 1114 aaaa
  8 rows selected

查出重复记录

SQL> select rowid,bm,mc from a where a.
  rowid!=(select max(rowid) from a b where a.bm=b.bm and
  a.mc=b.mc);
  ROWID BM MC
  ------------------ ---- ------------------
  AAAIRIAAQAAAAJqAAA 1111 aaaa
  AAAIRIAAQAAAAJqAAB 1112 aaaa
  AAAIRIAAQAAAAJqAAC 1113 aaaa
  AAAIRIAAQAAAAJqAAD 1114 aaaa

上一页  1 2 3 4  下一页

Tags:学习 Oracle 过程

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接