Oracle 12c 32k 与 rman recover table之间的 Bug
OracleDatabase12cRelease1(12.1.0.1.0)forLinuxx86-64OS:RedhatLinux5Update864bit1.按官方手册,启用 ..
Oracle Database 12c Release 1 (12.1.0.1.0) for Linux x86-64
OS: Redhat Linux 5 Update 8 64bit
1. 按官方手册,香港服务器,香港服务器,启用 varchar2 32k 支持
2. 使用 rman recover table 功能是,免备案空间,始终失败,报错如下:
RMAN-03015: error occurred in stored script Memory Script
RMAN-03009: failure of sql command on clone_default channel at 07/15/2013 13:03:14
RMAN-11003: failure during parse/execution of SQL statement: alter pluggable database PDB1 open read only
ORA-14693: The MAX_STRING_SIZE parameter must be EXTENDED.
3. 在未启用 varchar2 32k 支持时, rman recover table 成功。
经过多位朋友测试,均和我测试结果一致,证明是 Oracle 12.1.0.1.0 的Bug.
详细测试过程如下:
[oracle@AS5U8 trace]$ sqlplus gao/gao
SQL*Plus: Release 12.1.0.1.0 Production on Wed Jul 10 20:37:58 2013
Copyright (c) 1982, 2013, Oracle. All rights reserved.
Last Successful login time: Wed Jul 10 2013 19:34:02 +08:00
Connected to:
Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 – 64bit Production
With the Partitioning, OLAP, Advanced Analytics and Real Application Testing options
一 建立测试表
SQL> create table t1 (id number(1));
Table created.
SQL> insert into t1 values(1);
1 row created.
SQL> insert into t1 values(2);
1 row created.
SQL> commit;
Commit complete.
SQL> select * from t1;
ID
———-
1
2
SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;
TO_CHAR(SYSDATE,'YY
——————-
2013-07-10 20:38:46
二 进行一次 全备
[oracle@AS5U8 /]$ rman target sys/oracle
Recovery Manager: Release 12.1.0.1.0 – Production on Wed Jul 10 20:39:00 2013
Copyright (c) 1982, 2013, Oracle and/or its affiliates. All rights reserved.
connected to target database: NAIL (DBID=902387349)
RMAN> backup database format '/u01/backup/bak_%f';
Starting backup at 10-JUL-13
using target database control file instead of recovery catalog
allocated channel: ORA_DISK_1
channel ORA_DISK_1: SID=53 device type=DISK
channel ORA_DISK_1: starting full datafile backup set
channel ORA_DISK_1: specifying datafile(s) in backup set
input datafile file number=00001 name=/u01/product/oradata/nail/system01.dbf
input datafile file number=00003 name=/u01/product/oradata/nail/sysaux01.dbf
input datafile file number=00004 name=/u01/product/oradata/nail/undotbs01.dbf
input datafile file number=00006 name=/u01/product/oradata/nail/users01.dbf
channel ORA_DISK_1: starting piece 1 at 10-JUL-13
channel ORA_DISK_1: finished piece 1 at 10-JUL-13
piece handle=/u01/backup/bak_6 tag=TAG20130710T203920 comment=NONE
channel ORA_DISK_1: backup set complete, elapsed time: 00:01:15
channel ORA_DISK_1: starting full datafile backup set
channel ORA_DISK_1: specifying datafile(s) in backup set
including current control file in backup set
including current SPFILE in backup set
channel ORA_DISK_1: starting piece 1 at 10-JUL-13
channel ORA_DISK_1: finished piece 1 at 10-JUL-13
piece handle=/u01/backup/bak_0 tag=TAG20130710T203920 comment=NONE
channel ORA_DISK_1: backup set complete, elapsed time: 00:00:01
Finished backup at 10-JUL-13
三 继续写数据
SQL> insert into t1 values(3);
1 row created.
SQL> insert into t1 values(4);
1 row created.
SQL> commit;
Commit complete.
SQL> select * from t1;
ID
———-
1
2
3
4
SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;
TO_CHAR(SYSDATE,'YY
——————-
2013-07-10 20:41:20
SQL>
四 删除表
SQL> drop table t1 purge;
Table dropped.
SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;
TO_CHAR(SYSDATE,'YY
——————-
2013-07-10 20:41:56
五 RMAN 恢复 (报错)
[oracle@AS5U8 /]$ rman target sys/oracle

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

要查询 Oracle 表空间大小,请遵循以下步骤:确定表空间名称,方法是运行查询:SELECT tablespace_name FROM dba_tablespaces;查询表空间大小,方法是运行查询:SELECT sum(bytes) AS total_size, sum(bytes_free) AS available_space, sum(bytes) - sum(bytes_free) AS used_space FROM dba_data_files WHERE tablespace_

Oracle 安装失败的卸载方法:关闭 Oracle 服务,删除 Oracle 程序文件和注册表项,卸载 Oracle 环境变量,重新启动计算机。若卸载失败,可使用 Oracle 通用卸载工具手动卸载。

Oracle 视图加密允许您加密视图中的数据,从而增强敏感信息安全性。步骤包括:1) 创建主加密密钥 (MEk);2) 创建加密视图,指定要加密的视图和 MEk;3) 授权用户访问加密视图。加密视图工作原理:当用户查询加密视图时,Oracle 使用 MEk 解密数据,确保只有授权用户可以访问可读数据。

在 Oracle 中查看实例名的方法有三种:命令行中使用 "sqlplus" 和 "select instance_name from v$instance;" 命令。在 SQL*Plus 中使用 "show instance_name;" 命令。通过操作系统的任务管理器、Oracle Enterprise Manager 或检查环境变量 (Linux 上的 ORACLE_SID)。

解决 Oracle 游标关闭问题的方法包括:使用 CLOSE 语句显式关闭游标。在 FOR UPDATE 子句中声明游标,使其在作用域结束后自动关闭。在 USING 子句中声明游标,使其在关联的 PL/SQL 变量关闭时自动关闭。使用异常处理确保在任何异常情况下关闭游标。使用连接池自动关闭游标。禁用自动提交,延迟游标关闭。

在 Oracle 中删除所有数据需要以下步骤:1. 建立连接;2. 禁用外键约束;3. 删除表数据;4. 提交事务;5. 启用外键约束(可选)。请务必在执行前备份数据库,以防数据丢失。

Oracle 无效数字错误可能由数据类型不匹配、数字溢出、数据转换错误或数据损坏引起。排查步骤包括检查数据类型、检测数字溢出、检查数据转换、排查数据损坏,并探索其他可能的解决方案,如配置 NLS_NUMERIC_CHARACTERS 参数和启用数据验证日志记录。

可以通过使用 Oracle 的动态 SQL 来根据运行时输入创建和执行 SQL 语句。步骤包括:准备一个空字符串变量来存储动态生成的 SQL 语句。使用 EXECUTE IMMEDIATE 或 PREPARE 语句编译和执行动态 SQL 语句。使用 bind 变量传递用户输入或其他动态值给动态 SQL。使用 EXECUTE IMMEDIATE 或 EXECUTE 执行动态 SQL 语句。
