栏目导航
热点推荐
- Oracle数据库安全基础知识
- Oracle新手最常碰到的6个错误及
- Oracle数据库的使用技巧五则
- 将Oracle中的数据更改后出错的解
- 在不安装Oracle客户端的情况下进
- 讲解Oracle数据库冷备份恢复的具
- 当数据积累到一定时间后执行会越
- Oracle数据库环境下数据文件丢失
- Oracle数据库10g环境下修改VIP地
阅览排行
实例讲解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存储过程的异同