千家信息网

达梦使用联机SQL执行表空间还原(一)

发表于:2024-11-23 作者:千家信息网编辑
千家信息网最后更新 2024年11月23日,使用disql执行表空间还原介绍使用disql工具如何还原表空间。主要内容包括:1.使用表空间完全备份还原表空间2.使用表空间增量备份还原表空间3.使用数据库备份还原表空间1.使用表空间完全备份还原表
千家信息网最后更新 2024年11月23日达梦使用联机SQL执行表空间还原(一)

使用disql执行表空间还原
介绍使用disql工具如何还原表空间。主要内容包括:
1.使用表空间完全备份还原表空间
2.使用表空间增量备份还原表空间
3.使用数据库备份还原表空间

1.使用表空间完全备份还原表空间
表空间的还原、恢复操作是一次性完成,因此还原后不需要执行恢复操作。使用表空间完全备份还原表空间的完整步骤如下:
1) 配置归档。
2) 保证数据库处于OPEN或MOUNT状态。
3) 备份表空间。

SQL> backup tablespace main to ts_main_bak backupset 'E:\dmdbms\backup\ts_main_bak';操作已执行已用时间: 00:00:01.069. 执行号:9.

4) 校验表空间备份。此步骤为可选,如果确定备份文件合法可不进行备份校验。

SQL> select sf_bakset_check('disk','E:\dmdbms\backup\ts_main_bak');行号       SF_BAKSET_CHECK('disk','E:\dmdbms\backup\ts_main_bak')---------- ------------------------------------------------------1          1已用时间: 17.741(毫秒). 执行号:10.

5) 修改表空间为脱机。

SQL> alter tablespace main offline;操作已执行已用时间: 137.581(毫秒). 执行号:11.

6) 还原表空间。

SQL> restore tablespace main from backupset 'E:\dmdbms\backup\ts_main_bak';操作已执行已用时间: 276.897(毫秒). 执行号:12.

7) 修改表空间为联机。

SQL> alter tablespace main online;操作已执行已用时间: 17.971(毫秒). 执行号:13.

2.使用表空间增量备份还原表空间
在增量备份与基备份同目录情况下,使用增量备份还原表空间步骤与完全备份一致。当增量备份与基备份不在同一个目录下时需要使用RESTORE TABLESPACE...WITH BACKUPDIR语句还原。这里以后面一种情况为例说明使用增量备份还原表空间。步骤如下:
1) 配置归档。
2) 保证数据库处于OPEN或MOUNT状态。
3) 完全备份表空间。

SQL> backup tablespace main to ts_main_full_bak backupset 'E:\dmdbms\backup\ts_main_full_bak';操作已执行已用时间: 00:00:01.095. 执行号:35.

4) 多次增量备份表空间。

SQL> begin2   for i in 1 .. 100 loop3    insert into t1 values(i);4   end loop;5   commit;6   end;7   /DMSQL 过程已成功完成已用时间: 3.383(毫秒). 执行号:36.SQL> backup tablespace main increment with backupdir 'E:\dmdbms\backup\ts_main_full_bak' backupset 'E:\dmdbms\backup1\ts_main_incr_bak_01';操作已执行已用时间: 00:00:01.079. 执行号:37.SQL> begin2   for i in 101 .. 200 loop3   insert into t1 values(i);4   end loop;5   end;6   /DMSQL 过程已成功完成已用时间: 1.274(毫秒). 执行号:38.SQL> alter system switch logfile;操作已执行已用时间: 14.166(毫秒). 执行号:0.SQL> backup tablespace main increment with backupdir 'E:\dmdbms\backup\ts_main_full_bak','E:\dmdbms\backup1\ts_main_incr_bak_01' backupset 'E:\dmdbms\backup2\ts_main_incr_bak_02';操作已执行已用时间: 00:00:01.081. 执行号:39.

5) 校验表空间备份。此步骤为可选,如果确定备份文件合法可不进行备份校验。

SQL> select sf_bakset_check('disk','E:\dmdbms\backup\ts_main_full_bak');行号       SF_BAKSET_CHECK('disk','E:\dmdbms\backup\ts_main_full_bak')---------- -----------------------------------------------------------1          1已用时间: 20.931(毫秒). 执行号:40.SQL> select sf_bakset_check('disk','E:\dmdbms\backup1\ts_main_incr_bak_01');行号       SF_BAKSET_CHECK('disk','E:\dmdbms\backup1\ts_main_incr_bak_01')---------- ---------------------------------------------------------------1          1已用时间: 31.184(毫秒). 执行号:41.SQL> select sf_bakset_check('disk','E:\dmdbms\backup2\ts_main_incr_bak_02');行号       SF_BAKSET_CHECK('disk','E:\dmdbms\backup2\ts_main_incr_bak_02')---------- ---------------------------------------------------------------1          1已用时间: 25.171(毫秒). 执行号:42.

6) 修改表空间为脱机

SQL> alter tablespace main offline;操作已执行已用时间: 98.420(毫秒). 执行号:43.

7) 使用增量备份E:\dmdbms\backup2\ts_main_incr_bak_02还原表空间。

SQL> restore tablespace main from backupset 'E:\dmdbms\backup2\ts_main_incr_bak_02' with backupdir 'E:\dmdbms\backup\ts_main_full_bak','E:\dmdbms\backup1\ts_main_incr_bak_01';操作已执行已用时间: 370.046(毫秒). 执行号:44.

8) 修改表空间为联机。

SQL> alter tablespace main online;操作已执行已用时间: 15.717(毫秒). 执行号:45.SQL> select count(*) from t1;行号       COUNT(*)---------- --------------------1          200已用时间: 1.345(毫秒). 执行号:46.

3.使用数据库备份还原表空间
使用数据库备份还原表空间可以快速还原一个或多个表空间,而不影响数据库中其他的表空间和对象。在数据库中仅有特定的表空间损坏且没有表空间备份的情况下,可以选择使用此种方式还原。
具体步骤如下:
1) 配置归档。
2) 保证数据库处于OPEN或MOUNT状态。
3) 创建数据库完全备份。

SQL> backup database full to db_jydm_full_bak backupset 'E:\dmdbms\backup\ts_jydm_full_bak';操作已执行已用时间: 00:00:01.198. 执行号:50.

4) 校验表空间备份。此步骤为可选,如果确定备份文件合法可不进行备份校验。

SQL> select sf_bakset_check('disk','E:\dmdbms\backup\ts_jydm_full_bak');行号       SF_BAKSET_CHECK('disk','E:\dmdbms\backup\ts_jydm_full_bak')---------- -----------------------------------------------------------1          1已用时间: 46.115(毫秒). 执行号:51.

5) 修改表空间为脱机。

SQL> alter tablespace main offline;操作已执行已用时间: 96.596(毫秒). 执行号:52.

6) 还原表空间。

SQL> restore tablespace main from backupset 'E:\dmdbms\backup\ts_jydm_full_bak';操作已执行已用时间: 326.842(毫秒). 执行号:53.

7) 修改表空间为联机。

SQL> alter tablespace main online;操作已执行已用时间: 17.338(毫秒). 执行号:54.SQL> select count(*) from t1;行号       COUNT(*)---------- --------------------1          200已用时间: 1.969(毫秒). 执行号:55.
0