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表
一.自增型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 备份与恢复学习总结
- oracle学习总结1
- oracle学习总结-----------多表查询
- oracle学习总结------procedure
- Oracle 控制文件学习总结
- oracle学习总结----oracle常用命令
- oracle学习总结
- oracle学习总结一(基础)
- oracle学习总结(一)
- 总结ORACLE学习--8023
- Oracle学习总结(二)
- ORACLE执行计划学习总结
- oracle学习总结(一)---ROWID
- Oracle学习总结
- oracle简单学习总结(三)——函数
- Oracle学习—总结
- oracle简单学习总结(五)——数据操作(增删改)
- oracle简单学习总结(七)——表的锁定
- 存储过程学习总结(oracle多参数 insert)
- oracle简单学习总结(一)——sql