返回顶部
首页 > 资讯 > 数据库 >oracle12C 新特性——之在线重命名和移动数据文件
  • 451
分享到

oracle12C 新特性——之在线重命名和移动数据文件

2024-04-02 19:04:59 451人浏览 安东尼
摘要

【摘要】在12c版本之前,是不能够在线重命名和移动数据文件的。很多情况下,需要移动数据文件或重命名,那么只能停机操作了。但是到了12c,这个操作就变的非常简单了,可以在线操作,并且对应用业务没有任何影响,大

【摘要】

在12c版本之前,是不能够在线重命名和移动数据文件的。很多情况下,需要移动数据文件或重命名,那么只能停机操作了。

但是到了12c,这个操作就变的非常简单了,可以在线操作,并且对应用业务没有任何影响,大大提高了数据库高可用性。其实12c很多新特性都是为了提高数据库的高可用性而出来的,oracle对数据库高可用性方面越来越重视。

下面介绍12c的在线重命名和移动数据文件。

【正文】

一  在线重命名数据文件

首先,创建一个新的叫做TBS_FILE_TO_MOVE的表空间,该表空间只包含一个数据文件。

[oracle@Server ~]$sqlplus / as sysdba

 

SQL*Plus: Release12.1.0.1.0 Production on Fri Dec 20 03:03:50 2013

 

Copyright (c) 1982,2013, Oracle.  All rights reserved.

 

 

Connected to:

Oracle Database 12cEnterprise Edition Release 12.1.0.1.0 - 64bit Production

With thePartitioning, OLAP, Advanced Analytics and Real Application Testing options

 

SQL> CREATESMALLFILE TABLESPACE TBS_FILE_TO_MOVE  DATAFILE '/u01/app/oracle/oradata/NONCDB/file_to_move.dbf'

SIZE 100M AUTOEXTENDON NEXT 100M  LOGGING DEFAULT NOCOMPRESS

ONLINE  EXTENT MANAGEMENT LOCAL AUTOALLOCATE

SEGMENT SPACEMANAGEMENT AUTO

 

Tablespace created.

 

SQL> select name,status from v$datafile where name like '%file_to_move%'

 

NAME                                              STATUS

---------------------------------------------------------

/u01/app/oracle/oradata/NONCDB/file_to_move.dbf    ONLINE

 

SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*

/u01/app/oracle/oradata/NONCDB/file_to_move.dbf

 

对新创建的表空间TBS_FILE_TO_MOVE的数据文件"/u01/app/oracle/oradata/NONCDB/file_to_move.dbf"进行了在线重命名:

 

SQL>alter databasemove datafile '/u01/app/oracle/oradata/NONCDB/file_to_move.dbf' to'/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf'

 

Database altered.

 

如果在此步骤中尝试使用之前版本中提供的"alter database rename file"命令重命名数据文件的话,则会得到一个ORA-01121的错误,提示指定的数据文件在使用或者回复的同时不能进行重命名。

 

重命名操作完成之后,我们发现数据文件在控制文件和操作系统目录中已经显示为新的名字(file_to_move2.dbf),并且其状态仍然为ONLINE。

 

SQL>select name,status from v$datafile where name like '%file_to_move%'

 

NAME                                              STATUS

---------------------------------------------------------

/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf   ONLINE

 

SQL>!ls /u01/app/oracle/oradata/NONCDB/file_to_move*

/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf

二  使用KEEP关键字在线移动数据文件

 

使用带有KEEP关键字的"alter database move datafile……"语句,将数据文件file_to_move.dbf重命名为file_to_move1.dbf(模拟数据文件在线移动)。如果在操作中指定了KEEP关键字,则会在原来的位置保留原来的数据文件,并同时会在新的位置创建一个新的数据文件的副本,在这种情况下,当alter语句成功完成后,数据库将仅使用新的数据文件而不会使用原有位置的旧的数据文件。因此,操作完成之后,在控制文件中将仅能看到新的file_to_move1.dbf数据文件,但在操作系统目录中却能同时看到旧的(file_to_move2.dbf)和新的数据文件(file_to_move1.dbf)。

 

SQL>alter databasemove datafile '/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf' to'/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf' KEEP

 

Database altered.

 

SQL>select name,status from v$datafile where name like '%file_to_move%'

 

NAME                                              STATUS

---------------------------------------------------------

/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf   ONLINE

 

SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*

/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf  /u01/app/oracle/oradata/NONCDB/file_to_move2.dbf

三  使用REUSE关键字重命名一个在线数据文件

在"alter databasemove datafile..."语句中同时指定了REUSE关键字,这是因为在我们上一步的重命名操作中,我们曾经指定了KEEP关键字在原目录位置保留了数据文件file_to_move2.dbf,如果我们此时不指定REUSE关键字,我们的操作就会因目标数据件存在而报错,如果指定了REUSE关键字,则将会直接覆盖同名目标数据文件。

 

SQL>alter databasemove datafile '/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf' to'/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf' REUSE

 

Database altered.

 

 

Data files from thecontrol file:

SQL>select name,status from v$datafile where name like '%file_to_move%'

 

NAME                                               STATUS

---------------------------------------------------------

/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf   ONLINE

 

 

Data files from theOperating System Directory

SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*

/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf

四  使用文件号重命名一个在线数据文件

查询到数据文件file_to_move2.dbf所对应的数据文件号为100,接下来,我们直接使用数据文件file_to_move2.dbf对应的文件号(而不是具体指定其数据文件名称及位置)将其重命名为file_to_move1.dbf。

 

SQL>select name,status from v$datafile where name like '%file_to_move%'

 

NAME                                              STATUS

---------------------------------------------------------

/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf   ONLINE

 

 

Data files from theOperating System Directory

SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*

/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf

 

SQL>select file#from v$datafile where name = '/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf'

 

     FILE#

----------

       100

 

SQL>alter databasemove datafile 100 to '/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf'

 

SQL>select name,status from v$datafile where name like '%file_to_move%'

 

NAME                                              STATUS

---------------------------------------------------------

/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf   ONLINE

 

 

SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*

/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf

 

操作完成之后,通过v$datafile视图,确认控制文件中也已成功修改。


您可能感兴趣的文档:

--结束END--

本文标题: oracle12C 新特性——之在线重命名和移动数据文件

本文链接: https://lsjlt.com/news/46384.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • oracle12C 新特性——之在线重命名和移动数据文件
    【摘要】在12c版本之前,是不能够在线重命名和移动数据文件的。很多情况下,需要移动数据文件或重命名,那么只能停机操作了。但是到了12c,这个操作就变的非常简单了,可以在线操作,并且对应用业务没有任何影响,大...
    99+
    2024-04-02
  • oracle 12c新特性之在线移动数据文件
    11g时是无法在线移动数据文件的,12c增强了移动数据文件的功能,不仅可以更改路径,还可以给数据文件改名。 oracle 12c在线移动或更名数据文件语法案例: alter database mo...
    99+
    2024-04-02
  • Oracle 12.1新特性:在线rename或relocate数据文件
    在Oracle12.1之前的版本中要重命名数据文件或移动数据文件需要关闭数据库或把表空间/数据文件置为offline状态才可以,参考之前总结的Oracle修改数据文件名/移动数据文件。但到了12.1版本,可...
    99+
    2024-04-02
  • 在线移动oracle 数据文件位置
        在线移动oracle 数据文件 Oracle数据文件可以在数据库OPEN的时候被重命名或移动,但此时表空间必须为只读,这将允许用户从表中查询,但...
    99+
    2024-04-02
  • Java实现文件批量重命名,移动和删除
    目录一、题目描述-批量重命名1、题目2、解题思路3、代码详解二、题目描述-批量移动文件1、题目2、解题思路3、代码详解4、多学一个知识点三、题目描述-批量删除tmp文件1、题目2、解...
    99+
    2022-11-13
    Java文件重命名 Java文件 移动 Java文件 删除
  • 数据库重命名和迁移日志文件、数据文件的方法是什么
    本篇内容介绍了“数据库重命名和迁移日志文件、数据文件的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2024-04-02
  • Linux中批量移动、复制、追加和重命名文件的方法
    这篇文章主要介绍了Linux中批量移动、复制、追加和重命名文件的方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Linux中批量移动、复制、追加和重命名文件的方法文章都会有所收获,下面我们一起来看看吧。在 L...
    99+
    2023-06-27
  • mysql事件之修改事件、禁用事件、启用事件、事件重命名及数据库事件迁移操作的示例分析
    这篇文章主要为大家展示了“mysql事件之修改事件、禁用事件、启用事件、事件重命名及数据库事件迁移操作的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“m...
    99+
    2024-04-02
  • 文件处理和数据类型在ASP面试中的重要性是什么?
    ASP是一种用于开发Web应用程序的技术,它使用一些特定的编程语言,例如VBScript和JScript。在ASP面试中,文件处理和数据类型是两个非常重要的话题。本文将探讨这两个话题的重要性以及如何在ASP中使用它们。 文件处理的重要性 ...
    99+
    2023-08-30
    面试 文件 数据类型
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作