DIY编程器网

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 914|回复: 0
打印 上一主题 下一主题

[待整理] 实例讲解Oracle数据库自动增加ID的sql

[复制链接]
跳转到指定楼层
楼主
发表于 2014-10-13 13:49:44 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  本文的主要内容包括:在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表
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|文字版|手机版|DIY编程器网 ( 桂ICP备14005565号-1 )

GMT+8, 2024-11-17 02:33 , 耗时 0.083520 秒, 19 个查询请求 , Gzip 开启.

各位嘉宾言论仅代表个人观点,非属DIY编程器网立场。

桂公网安备 45031202000115号

DIY编程器群(超员):41210778 DIY编程器

DIY编程器群1(满员):3044634 DIY编程器1

diy编程器群2:551025008 diy编程器群2

QQ:28000622;Email:libyoufer@sina.com

本站由桂林市临桂区技兴电子商务经营部独家赞助。旨在技术交流,请自觉遵守国家法律法规,一旦发现将做封号删号处理。

快速回复 返回顶部 返回列表