设为首页 加入收藏

TOP

oracle学习总结(二)
2011-06-09 13:10:02 来源: 作者: 【 】 浏览:486次 评论:0



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

您看到此篇文章时的感受是:
Tags: 责任编辑:administrator
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到QQ空间
分享到: 
上一篇升级Webwork2.2版本注意点 下一篇select into 和 insert into

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

相关栏目

最新文章

图片主题

热门文章

推荐文章

相关文章

广告位