oracle学习总结(二)
一.自增型ID
1.首先创建 sequence
create sequence seqmax increment by 1
2.得到一个ID
select seqmax.nextval ID from dual
3.若要删除一个sequence
drop sequence seqmax;
二.删除数据表中的重复记录create sequence seqmax increment by 1
2.得到一个ID
select seqmax.nextval ID from dual
3.若要删除一个sequence
drop sequence seqmax;
1.先创建一个表
CREATETABLE"APPTEST"(
"ID"INTEGERprimarykeyNOTNULL,
"MOBILE"nvarchar2(50)NOTNULL
);
2.假设其中手机号大量重复,要删除重复记录,可以有如下两种方法:
(1)简单利用rowid删除
deletefromAPPTESTawhererowidnotin(selectmax(rowid)fromAPPTESTbwherea.mobile=b.mobile);
据说,这种方法在数据量很大时,效率并不高
(2)利用分析函数
deleteAPPTESTwhererowidin(
selectridfrom
(selectrowidrid,row_number()over(partitionbymobileorderbyiddesc)rnfromAPPTEST)
wherern>1);
(3)做temp表




(1)简单利用rowid删除

据说,这种方法在数据量很大时,效率并不高
(2)利用分析函数



