• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Oracle如何更改表空间的数据文件位置详解

    表空间概述

    Oracle的表空间属于Oracle中的存储结构,是一种用于存储数据库对象(如:数据文件)的逻辑空间,是Oracle中信息存储的最大逻辑单元,其下还包含有段、区、数据块等逻辑数据类型。表空间是在数据库中开辟的一个空间,用于存放数据库的对象,一个数据库可以由多个表空间组成。可以通过表空间来实现对Oracle的调优。(Oracle数据库独特的高级应用)

    表空间的分类

    永久表空间:存储数据库中需要永久化存储的对象,比如二维表、视图、存储过程、索引。

    临时表空间:存储数据库的中间执行过程,如:保存order by数据库排序,分组时产生的临时数据。操作完成后存储的内容会被自动释放。临时表空间是通用的,所的用户都使用TEMP作为临时表空间。一般只有tmp一个临时表空间,如果还需要别的临时表空间时,可以自己创建。

    UNDO表空间:保存数据修改前的副本。存储事务所修改的旧址,即被修改之前的数据。当我们对一张表中的数据进行修改的同时会对修改之前的信息进行保存,为了对数据执行回滚、恢复、撤销的操作。

    引言

    Oracle数据库的数据文件的位置和信息都被记录在控制文件中,rm或cp命令是不会也不可能更改控制文件记录的,这时必须通过alter操作去更改刷新数据库控制文件中数据文件的相关信息,以此确保数据库能够正常运行。

    操作方法

    1. 方法1

    主要步骤:

          1、offline表空间:alter tablespace tablespace_name offline;

          2、复制数据文件到新的目录;

          3、rename修改表空间,并修改控制文件;

          4、online表空间;

    offline表空间

    SQL> alter tablespace cifdb offline;

    复制数据文件到新的目录

    cp /u01/app/oracle/oradata/cifdb.dbf /u01/app/oracle/oradata/CIFDB/cifdb.dbf

    rename修改表空间

    SQL> alter tablespace cifdb rename datafile '/u01/app/oracle/oradata/cifdb.dbf' to '/u01/app/oracle/oradata/CIFDB/cifdb.dbf';

    online表空间

    SQL> alter tablespace cifdb online;

    检查数据文件

    SQL> select name from v$datafile;

    或者

    SQL> select file_name, tablespace_name from dba_data_files where tablespace_name='cifdb';

    2. 方法2

    主要步骤:

          1、关闭数据库;

          2、复制数据文件到新的位置;

          3、启动数据库到mount状态;

          4、通过SQL修改数据文件位置;

          5、打开数据库;

    关闭数据库

    SQL> shutdown immediate;

    复制数据文件到新的位置

    cp /u01/app/oracle/oradata/cifdb.dbf /u01/app/oracle/oradata/CIFDB/cifdb.dbf

    启动数据库到mount状态

    SQL> startup mount;

    修改数据文件位置

    SQL> alter database rename file '/u01/app/oracle/oradata/cifdb.dbf' to '/u01/app/oracle/oradata/CIFDB/cifdb.dbf';

    打开数据库

    SQL> alter database open;

    检查数据文件

    SQL> select name from v$datafile;

    或者

    SQL> select file_name, tablespace_name from dba_data_files where tablespace_name='cifdb';

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

    您可能感兴趣的文章:
    • Oracle表空间数据文件移动的方法
    • Oracle7.X 回滚表空间数据文件误删除处理方法
    • Oracle7.X 回滚表空间数据文件误删除处理方法
    • Oracle7.X 回滚表空间数据文件误删除处理方法
    • Oracle如何设置表空间数据文件大小
    上一篇:Oracle RMAN还原时set newname文件名有空格报错的解决方法
    下一篇:Oracle 11g服务器安装详细步骤图文详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Oracle如何更改表空间的数据文件位置详解 Oracle,如何,更改,表空,间的,