DM据库移动数据文件方法说明


前言

在达梦数据库中,TEMP 临时表空间是DB自己维护的,我们不用单独管理。 对于业务表空间的数据库,我们可以直接改变其存储路径,比如当磁盘空间不足时,将数据文件转移到其他磁盘目录中。


一、移动方法

操作方法有两种:

1.使用SQL,将表空间离线,rename 数据文件路径,在online 表空间。 该方法同Oracle 12c 之前的版本操作一致,但不需要物理移动数据文件。 Oracle 也是到12c 以后才支持在线移动数据文件。

2. 停库,移动数据文件,重建控制。

这里演示第一种方法,使用SQL语句来操作。


二、操作步骤

1.创建表空间

使用disql工具登录数据库:
cd /home/dmdba/dmdbms/bin
./disql SYSDBA/SYSDBA@localhost:5236

查看当前表空间情况:

select tablespace_name, file_name, status from dba_data_files order by 1;

在这里插入图片描述
创建一个新的表空间:

create tablespace test datafile '/home/dmdba/dmdbms/data/DAMENG/test01.DBF' size 32, '/home/dmdba/dmdbms/data/DAMENG/test02.DBF' size 32;

在这里插入图片描述
然后再次查看表空间情况:

select tablespace_name, file_name, status from dba_data_files order by 1;

在这里插入图片描述
创建完成。

2.OFFLINE表空间并移动数据文件位置

首先offline新创建的表空间test

alter tablespace test offline;

在这里插入图片描述

然后将表空间文件移动到/home/dmdba/目录下:

alter tablespace test rename datafile '/home/dmdba/dmdbms/data/DAMENG/test01.DBF' to '/home/dmdba/test01.dbf';
alter tablespace test rename datafile '/home/dmdba/dmdbms/data/DAMENG/test02.DBF' to '/home/dmdba/test02.dbf';

在这里插入图片描述
然后online表空间test:

alter tablespace test online;

在这里插入图片描述

查看表空间状况:

select tablespace_name, file_name, status from dba_data_files order by 1;

在这里插入图片描述
移动成功。


三、注意事项

1.rename

注意这里的rename 即修改控制文件,也进行物理操作,不再需要单独在操作系统上移动数据文件:

ls -l /home/dmdba/dmdbms/data/DAMENG/test0*
ls -l /home/dmdba/test0*

在这里插入图片描述

2.其他表空间能否移动

这里除了TEMP、SYSTEM 、ROLL 三个系统表空间不能移动之外,其他表空间都可以移动:

alter tablespace SYSTEM offline;
alter tablespace roll offline;
alter tablespace temp offline;

在这里插入图片描述


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值