您的位置:首页 > 数据库 > Oracle

oracle学习总结(二)

2007-05-24 09:29 381 查看
本文的主要内容包括:在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(50) NOT 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表
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: