科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道oracle学习总结(二)

oracle学习总结(二)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

在oracle中实现自增型ID,删除数据表中的重复记录.

作者:扬州梦 来源:CSDN 2008年3月30日

关键字: 总结 学习 ORACLE 数据库

  • 评论
  • 分享微博
  • 分享邮件
本文的主要内容包括:在oracle中实现自增型ID,删除数据表中的重复记录
一.自增型ID
1.首先创建 sequence
create sequence seqmax increment by 1
2.得到一个ID
select seqmax.nextval ID from dual
3.若要删除一个sequence
drop sequence seqmax;
二.删除数据表中的重复记录
1.先创建一个表
CREATE TABLE "APPTEST" (
  "ID" 
INTEGER primary key NOT NULL,
  "MOBILE" nvarchar2(
50NOT NULL
);
2.假设其中手机号大量重复,要删除重复记录,可以有如下两种方法:
(1)简单利用rowid删除
delete from APPTEST a where rowid not in (select max(rowid) from APPTEST b where a.mobile=b.mobile);

据说,这种方法在数据量很大时,效率并不高
(2)利用分析函数
delete APPTEST where rowid in (
select rid from
(
select rowid rid,row_number() over(partition by mobile order by id desc) rn from APPTEST )
where rn > 1) ;
(3)做temp表

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章