重庆思庄Oracle、Redhat认证学习论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1453|回复: 0
打印 上一主题 下一主题

[Oracle] :oracle数据库中删除表后创建同名表,如何闪回删除后的表?

[复制链接]
跳转到指定楼层
楼主
发表于 2022-11-10 10:43:01 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
问题描述:oracle数据库中删除表后创建同名表,如何闪回删除后的表?
数据库:oracle11.2.0.4 64
系统:centos7.9 64
1、模拟异常
SQL>select count(*) from test;
  COUNT(*)
----------
    256000
SQL>select object_name,original_name,operation,type from user_recyclebin;
no rowsselected
SQL>drop table test;
Tabledropped.
SQL>set line 200
SQL>col type for a15
SQL>select object_name,original_name,operation,type from user_recyclebin
OBJECT_NAME                    ORIGINAL_NAME                    OPERATION TYPE
-------------------------------------------------------------- --------- ---------------
BIN$7LGIbMiPDmXgU9mFqMA7vQ==$0TEST                            DROP      TABLE
创建同名表.
SQL>create table test (id number(6,2),
  2                     name varchar2(20));
Tablecreated.
SQL>begin
  2   for i in 1..20 loop
  3   insert into test values (i,'a' || i);
  4   end loop;
  5  end;
  6  /
PL/SQLprocedure successfully completed.
SQL>select count(*) from test;
  COUNT(*)
----------
        20
SQL>commit;
Commitcomplete.
SQL>select object_name,original_name,operation,type from user_recyclebin;
OBJECT_NAME                    ORIGINAL_NAME                    OPERATION TYPE
-------------------------------------------------------------- --------- ---------------
BIN$7LGIbMiPDmXgU9mFqMA7vQ==$0TEST                            DROP      TABLE
SQL>flashback table test to before drop;
flashbacktable test to before drop
*
ERROR atline 1:
ORA-38312:original name is used by an existing object
说明:如上所示,闪回表时出现ORA-38312告警.
2、解决方案2.1、指定新表名
SQL>flashback table test to before drop rename to test01;
Flashbackcomplete.
SQL>select count(*) from test01;
  COUNT(*)
----------
    256000
SQL>select table_name from user_tables;
TABLE_NAME
------------------------------
TEST
TEST01
2.2rename新表
SQL>drop table test;
Tabledropped.
SQL>create table test (id number(6,2),
  2                     name varchar2(20));
Tablecreated.
SQL>begin
  2   for i in 1..20 loop
  3   insert into test values (i,'a' || i);
  4   end loop;
  5  end;
  6  /
PL/SQLprocedure successfully completed.
SQL>commit;
Commitcomplete.
SQL>select table_name from user_tables;
TABLE_NAME
------------------------------
TEST
TEST01
对表test重新命令为其它表名.
SQL>alter table test rename to test02;
Tablealtered.
SQL>select object_name,original_name,operation,type from user_recyclebin;
OBJECT_NAME                    ORIGINAL_NAME                    OPERATION TYPE
-------------------------------------------------------------- --------- ---------------
BIN$7LGIbMiQDmXgU9mFqMA7vQ==$0TEST                            DROP      TABLE
SQL>flashback table test to before drop;
Flashbackcomplete.
SQL>select table_name from user_tables;
TABLE_NAME
------------------------------
TEST02
TEST
TEST01

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 支持支持 反对反对
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|重庆思庄Oracle、Redhat认证学习论坛 ( 渝ICP备12004239号-4 )

GMT+8, 2024-11-29 10:29 , Processed in 0.134955 second(s), 21 queries .

重庆思庄学习中心论坛-重庆思庄科技有限公司论坛

© 2001-2020

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