首页
学习
活动
专区
工具
TVP
发布

Oracle删除索引规范

1.背景概述 近期应用升级上线过程中,存在删除业务表索引的变更操作,且因删除索引导致次日业务高峰时期,数据库响应缓慢的情况,经定位是缺失索引导致。...与用户沟通,虽然变更中删除索引的需求很少,但也存在此类需求。 本文从数据库层面,旨在尽可能避免类似问题发生,制定删除索引的变更规范。...2.索引删除规范 若确认需要做索引删除,可以使用Oracle提供的两个功能特性协助判断删除索引是否会有隐患。...2.2 将删除索引先修改为不可见 将计划要删除的索引设置为不可见(invisible),然后经历至少一个业务周期(具体业务确认业务周期为多久,注意要考虑到跑批场景)的观察,确认没有影响,则可以考虑彻底删除...一般原则是首先评估删除冗余索引,比如某张表同时有两个索引,索引A是c1列,索引B是c1,c2两列的复合索引,则一般可以选择删除索引A;但需要注意,如果索引B是c2和c1列的复合索引,就通常不可以删除索引

1.3K30
您找到你想要的搜索结果了吗?
是的
没有找到

oracle恢复删除数据

原理: 利用oracle提供的闪回方法,如果在删除数据后还没做大量的操作(只要保证被删除数据的块没被覆写),就可以利用闪回方式直接找回删除的数据 具体步骤为: *确定删除数据的时间(在删除数据之前的时间就行...,不过最好是删除数据的时间点) *用以下语句找出删除的数据:select * from 表名 as of timestamp to_timestamp(‘删除时间点’,’yyyy-mm-dd hh24:...原理:由于oracle删除表时,没有直接清空表所占的块,oracle把这些已删除的表的信息放到了一个虚拟容器“回收站”中,而只是对该表的数据块做了可以被覆写的标志,所以在块未被重新使用前还可以恢复。...然后再重命名,参照以下语句: flashback table “回收站中的表名(如:BinDSbdfd4rdfdfdfegdfsf==0)” to before drop rename to 新表名 oracle...SQL>flashback database to timestamp to_timestamp(‘2007-2-12 12:00:00′,’yyyy-mm-dd hh24:mi:ss’); 总结: oracle

2K20

Oracle 级联删除外键

所谓的级联删除是指当主表中的一条记录被删除,那么子表中所关联的记录也相应的自动删除。本教程将教大家如何在Oracle中使用级联删除外键。...使用CREATE TABLE语句定义级联删除 以下是使用CREATE TABLE语句定义级联删除的语法: CREATE TABLE table_name ( column1 datatype null...由于级联删除,当supplier表中的记录被删除时,products表中相应的所有记录也将被删除,因为这些记录具有相同的supplier_id值。...根据supplier_id和supplier_name删除supplier表中的记录时,外键fk_foreign_comp上的级联删除会导致products表中的所有对应记录也会被级联删除。...使用ALTER TABLE语句定义级联删除 除了CREATE TABLE语句外,我们还可以用ALTER TABLE语句定义级联删除,具体语法如下: ALTER TABLE table_name ADD

1.1K30

linux删除用户名命令,linux删除用户命令

Linux删除以后的时候我们需要通过相关的命令来实现。下面由学习啦小编为大家整理linux删除用户命令的相关知识,希望对大家有帮助!...linux删除用户命令简介 userdel 是一个底层用于删除用户的工具。在 Debian 上,我们通常会使用 deluser 命令。...那么它会删除所有和用户名相关的条目。在我们删除它之前,用户名必须存在。 linux删除用户命令的用法 由于 userdel 会修改系统账户文件,那么我们需要root特权来运行它。...甚至当用户已经登入 Linux 系统时此选项仍旧生效。请看一下示例截图。 截图的上面显示用户 pasadena 已经登录了系统。它被标记的进程6218是 SSHD 进程。...补充:linux删除用户命令userdel总结 上面就是Linux使用userdel命令删除用户账号的方法介绍了,userdel命令不仅能够用来删除系统用户账号,还能用于删除文件。

18.1K30

java删除linux文件_Java删除文件

//将缓冲文件夹中的文件删除 String s = “D:\\txt\\inBuffer\\”+ fileInfo[0] +”\\” + fileID;//文件的绝对路径 File file = new...File(s); if(file.exists()){ boolean d = file.delete(); if(d){ System.out.print(“删除成功!”)...; }else{ System.out.print(“删除失败!”)...; } } ——————————————————————————– Java删除文件注意事项:1.路径上不能出现java认为的非法字符,如“(”,“)”等; 2.确保删除操作之前,文件不再被使用,即文件资源被释放...——————————————————————————– java删除文件与文件夹时,要删除的内容: 1.文件夹里的文件; 2.文件夹里面的子文件夹(有文件); 3.文件夹里面的子文件夹(空文件夹); —

19.4K20

oracle恢复删除的数据时长_oracle 闪回查询语句

ORACLE恢复删除的数据 在网络搜集整理了关于恢复oracle已经删除或更新的数据方法,供参考; oracle提供了针对已经删除的数据恢复;分为两种方法:scn和时间戳两种方法恢复。...一、通过scn恢复删除且已提交的数据   1、获得当前数据库的scn号     select current_scn from v$database; (切换到sys用户或system用户查询)     ...如果不是,则继续缩小scn号)   3、恢复删除且已提交的数据     flashback table 表名 to scn 1499220; 二、通过时间恢复删除且已提交的数据   1、查询当前系统时间...可以尝试执行 alter table 表名 enable row movement; //允许更改时间戳 三、oracle数据update后怎么恢复到以前的数据 –查出你需要恢复的时间点 1、select...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除

76220

oracle中如何删除重复数据

一、对于部分字段重复数据的删除         先来谈谈如何查询重复的数据吧。        ...想要删除这些重复的数据,可以使用下面语句进行删除   delete from 表名 a where 字段1,字段2 in     (select 字段1,字段2,count(*) from 表名 group...不过这种删除执行的效率非常低,对于大数据量来说,可能会将数据库吊死。所以我建议先将查询到的重复的数据插入到一个临时表中,然后对进行删除,这样,执行删除的时候就不用再进行一次查询了。...下面就可以进行这样的删除操作了:   delete from 表名 a where 字段1,字段2 in (select 字段1,字段2 from 临时表);         这种先建临时表再进行删除的操作要比直接用一条语句进行删除要高效得多...在oracle中,有个隐藏了自动rowid,里面给每条记录一个唯一的rowid,我们如果想保留最新的一条记录, 我们就可以利用这个字段,保留重复数据中rowid最大的一条记录就可以了。

2.3K30
领券