源码下载 | 网页特效 | 广告代码 | 素材下载 | 站长工具
会员投稿 投稿指南 RSS订阅
您当前的位置是:主页>网络编程>Oracle教程>

实例讲解Oracle数据库自动增加ID的sql

www.jz123.cn  2008-08-02   来源:   中国建站    乐乐整理    我要投递新闻

本文的主要内容包括:在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表

上一篇:Oracle中忘记System和Sys密码后的处理方法 下一篇:经验分享:Informix和Oracle存储过程的异同

评论总数:1 [ 查看全部 ] 网友评论


关于我们隐私版权广告服务友情链接联系我们网站地图