当前位置: 首页 > news >正文

oracle删除重复的数据

去除重复数据:

group by 对要比对的字段进行查询是否重复

CREATE TABLE 临时表 AS

(select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1)

上面这句话就是建立了临时表,并将查询到的数据插入其中。

下面就可以进行这样的删除操作了:

delete from 表名 a where 字段1,字段2 in (select 字段1,字段2 from 临时表);

使用rowid 会保存最新的一条记录:

delete from 表名 a

where a.rowid !=

(

select max(b.rowid) from 表名 b

where a.字段1 = b.字段1 and

a.字段2 = b.字段2

)

---效率好点的要使用临时表

create table 临时表 as

select a.字段1,a.字段2,MAX(a.ROWID) dataid from 正式表 a GROUP BY a.字段1,a.字段2;

delete from 表名 a

where a.rowid !=

(

select b.dataid from 临时表 b

where a.字段1 = b.字段1 and

a.字段2 = b.字段2

);

commit;

完全删除重复的数据:

CREATE TABLE 临时表 AS (select distinct * from 表名);

drop table 正式表;

insert into 正式表 (select * from 临时表);

drop table 临时表;

http://www.lryc.cn/news/231013.html

相关文章:

  • Python中的并发编程是什么,如何使用Python进行并发编程?
  • 【LeetCode】136. 只出现一次的数字
  • HTTP服务器——tomcat的安装和使用
  • 代码随想录Day45 动态规划13 LeetCode T1143最长公共子序列 T1135 不相交的线 T53最大子数组和
  • 写了个监控 ElasticSearch 进程异常的脚本!
  • 第三篇 基于JSP 技术的网上购书系统—— 数据库系统设计(网上商城、仿淘宝、当当、亚马逊)
  • 电脑检测温度软件有哪些?
  • 设计模式 -- 单例模式(Singleton Pattern)
  • ubuntu给终端加代理服务器
  • centos 6.10 安装 readline 6.2.0
  • IDEA 2023搭建 SpringMVC +FreeMarker+JDBC
  • RabbitMQ传统数据持久化和Lazy queue的区别
  • docker部署lnmp环境
  • 数据结构 | 带头双向循环链表专题
  • Redis使用Pipeline(管道)批量处理
  • Linux中at命令添加一次性任务
  • 交换机基础知识之安全配置
  • Netty入门指南之Reactor模型
  • Ubuntu20.04软件安装顺序
  • 适配器模式 ( Adapter Pattern )(6)
  • JAVA G1垃圾收集器介绍
  • 十方影视后期“领进门”,成长与成就还得靠自身
  • Golang之火爆原因
  • WPF中Dispatcher对象的用途是什么
  • 图论17-有向图的强联通分量-Kosaraju算法
  • ubuntu中使用 vscode 连接docker开发环境
  • 【广州华锐视点】海外制片人VR虚拟情景教学带来全新的学习体验
  • 龙芯loongarch64麒麟服务器配置yum源
  • Centos7 单用户模式修改密码 3步搞定 666 (百分比成功)
  • 深度学习 机器视觉 车位识别车道线检测 - python opencv 计算机竞赛