您现在的位置是: 上海IT外包服务网 ->数据库 ->oracle(3) ->
本文关键字: 删除数据表中的重复记录
删除数据表中的重复记录
作者: 不详 | 发布时间: 2007-03-06 16:41 | 信息类别: oracle(3) | 访问人次:
评论 推荐 打印 编辑 】 【 关闭
  
  
删除数据表中的重复记录


删除交通违章数据表中的重复记录(同一时间[haptime]、车号牌[numberplate]、处罚原因[reason])
一、方法原理:
  1、Oracle中,每一条记录都有一个rowid,rowid在整个数据库中是唯一的,  rowid确定了每条记录是在ORACLE中的哪一个数据文件、块、行上。
  2、在重复的记录中,可能所有列的内容都相同,但rowid不会相同,所以只要确定出重复记录中那些具有最大rowid的就可以了,其余全部删除


二、实现方法:
1、查询重复记录
select rowid,haptime,numberplate,reason from peccancy
--delete from peccancy6 peccancy6
where peccancy.rowid !=
(
select max(rowid) from peccancy b
where peccancy.haptime = b.haptime and
peccancy.numberplate = b.numberplate and
peccancy.reason = b.reason
)



2、删除重复记录
delete from peccancy peccancy
where peccancy.rowid !=
(
select max(rowid) from peccancy b
where peccancy.haptime = b.haptime and
peccancy.numberplate = b.numberplate and
peccancy.reason = b.reason
)
评论 推荐 打印 编辑 】 【 关闭
『相关链接』
【郑重声明】【上海IT外包服务网】 刊载此文不代表同意其说法或描述,仅为提供更多信息,也不构成任何投资或其他建议。转载需经作者本人同意并注明出处。本网站有部分文章是由网友自由上传。对于此类文章本站仅提供交流平台,不为其版权负责。如果您发现本网站上有侵犯您的知识产权的文章,请发信至 或直接电话联系: 021-61121021
请您留言
『发表评论』
匿名发表 会员ID: 密码:

上海网炬网络科技有限公司
上海徐家汇 漕溪北路38号11楼A室 +0086-21-61121 021 3003303
w71365@gmail.com +0086-21-64877858w71365@gmail.com
Copyright@2007 71365.COM Inc.沪b-20050252 版权所有2007-2010 管理员登陆