Oracle RMAN模拟数据文件丢失简单恢复方法
1 Oracle创建简单项目环境1)创建表空间SQLgt; create tablespace dreamtry_tbs datafile
1 Oracle创建简单项目环境
1)创建表空间
SQL> create tablespace dreamtry_tbs datafile 'd:\oracledate\dreamtry_tbs01.dbf' size 100M;
表空间已创建。
2)创建用户
SQL> create user dreamtry identified by dreamtry;
用户已创建。
3)给用户分配表空间
SQL> alter user dreamtry default tablespace dreamtry_tbs quota unlimited on dreamtry_tbs;
用户已更改。
4)取消用户对表空间都拥有写权限(这点非必须,建议执行)
SQL> alter user dreamtry default tablespace dreamtry_tbs quota unlimited on dreamtry_tbs;
用户已更改。
5)给用户分配基本权限 (可以加上with admin option)
SQL> grant connect,resource to dreamtry;
授权成功。
6)切换用户
SQL> conn dreamtry/dreamtry;
已连接。
2 模拟数据文件丢失的恢复(前提是以前有过备份,并且有日志)
1) 备份数据文件
RMAN> backup datafile 'd:\oracledate\dreamtry_tbs01.dbf' format 'D:\oracle\product\10.2.0\oradata\orcl\dreamtry_tbs01.dbf';
启动 backup 于 01-3月 -12
使用目标数据库控制文件替代恢复目录
分配的通道: ORA_DISK_1
通道 ORA_DISK_1: sid=145 devtype=DISK
通道 ORA_DISK_1: 启动全部数据文件备份集
通道 ORA_DISK_1: 正在指定备份集中的数据文件
输入数据文件 fno=00007 name=D:\ORACLEDATE\DREAMTRY_TBS01.DBF
通道 ORA_DISK_1: 正在启动段 1 于 01-3月 -12
通道 ORA_DISK_1: 已完成段 1 于 01-3月 -12
段句柄=D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\DREAMTRY_TBS01.DBF 标记=TAG20120301T223142 注释=NONE
通道 ORA_DISK_1: 备份集已完成, 经过时间:00:00:03
完成 backup 于 01-3月 -12
2) 切换用户dreamtry模拟数据操作
SQL> conn dreamtry/dreamtry;
已连接。
SQL> create table test(id number(10), name varchar2(20));
表已创建。
SQL> insert into test(id,name) values(1,'zhangsan');
已创建 1 行。
SQL> select * from test;
ID NAME
---------- --------------------
1 zhangsan
3) 模拟数据文件dreamtry_tbs01.dfb丢失
手工删除OS文件dreamtry_tbs01.dbf(移到别处也可,以防万一)
SQL> startup
ORACLE 例程已经启动。
Total System Global Area 612368384 bytes
Fixed Size 1250428 bytes
Variable Size 251661188 bytes
Database Buffers 352321536 bytes
Redo Buffers 7135232 bytes
数据库装载完毕。
ORA-01157: 无法标识/锁定数据文件 7 - 请参阅 DBWR 跟踪文件
ORA-01110: 数据文件 7: 'D:\ORACLEDATE\DREAMTRY_TBS01.DBF'
SQL> select status from v$instance;
STATUS
------------
MOUNTED
如上数据库只能启动mount状态.
4) 使用备份的数据文件恢复(当然在有日志的情况下没有备份也是可以恢复的)
RMAN> restore datafile 7;
启动 restore 于 01-3月 -12
使用通道 ORA_DISK_1
通道 ORA_DISK_1: 正在开始恢复数据文件备份集
通道 ORA_DISK_1: 正在指定从备份集恢复的数据文件
正将数据文件00007恢复到D:\ORACLEDATE\DREAMTRY_TBS01.DBF
通道 ORA_DISK_1: 正在读取备份段 D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\DREAMTRY_TBS01.DBF
通道 ORA_DISK_1: 已恢复备份段 1
段句柄 = D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\DREAMTRY_TBS01.DBF 标记 = TAG20120301T223142
通道 ORA_DISK_1: 恢复完成, 用时: 00:00:04
完成 restore 于 01-3月 -12
5) 通过日志恢复备份以后操作数据库的内容
RMAN> recover datafile 7;
启动 recover 于 01-3月 -12
使用通道 ORA_DISK_1
正在开始介质的恢复
介质恢复完成, 用时: 00:00:03
完成 recover 于 01-3月 -12
6) 打开数据库
RMAN> alter database open;
数据库已打开
7) 验证数据
SQL> select * from dreamtry.test;
ID NAME
---------- --------------------
1 zhangsan
8) 由于是模拟,我还是把备份删掉以免占用空间
RMAN> list backup;
备份集列表
===================
BS 关键字 类型 LV 大小 设备类型 经过时间 完成时间
------- ---- -- ---------- ----------- ------------ ----------
3 Full 88.00K DISK 00:00:02 01-3月 -12
BP 关键字: 3 状态: AVAILABLE 已压缩: NO 标记: TAG20120301T223142
段名:D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\DREAMTRY_TBS01.DBF
备份集 3 中的数据文件列表
文件 LV 类型 Ckp SCN Ckp 时间 名称
---- -- ---- ---------- ---------- ----
7 Full 1068184 01-3月 -12 D:\ORACLEDATE\DREAMTRY_TBS01.DBF
RMAN> delete backupset 3;
分配的通道: ORA_DISK_1
通道 ORA_DISK_1: sid=145 devtype=DISK
备份段列表
BP 关键字 BS 关键字 Pc# Cp# 状态 设备类型段名称
------- ------- --- --- ----------- ----------- ----------
3 3 1 1 AVAILABLE DISK D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\DREAMTRY_TBS01.DBF
是否确定要删除以上对象 (输入 YES 或 NO)? YES
已删除备份段
备份段 handle=D:\ORACLE\PRODUCT\10.2.0\ORADATA\ORCL\DREAMTRY_TBS01.DBF recid=3 stamp=776817102
1 对象已删除
RMAN> crosscheck backup;
使用通道 ORA_DISK_1
RMAN> delete expired backup;
使用通道 ORA_DISK_1
9) 结论:日志是最后一道防线,所以最好先备份,最好也对archive log也备份,还是以防万一.

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Artikel ini meneroka mengoptimumkan penggunaan memori MySQL di Docker. Ia membincangkan teknik pemantauan (statistik Docker, skema prestasi, alat luaran) dan strategi konfigurasi. Ini termasuk had memori docker, swapping, dan cgroups, bersama -sama

Artikel ini menangani ralat "tidak dapat membuka perpustakaan kongsi" MySQL. Isu ini berpunca daripada ketidakupayaan MySQL untuk mencari perpustakaan bersama yang diperlukan (.so/.dll fail). Penyelesaian melibatkan mengesahkan pemasangan perpustakaan melalui pakej sistem m

Artikel ini membincangkan menggunakan pernyataan jadual Alter MySQL untuk mengubah suai jadual, termasuk menambah/menjatuhkan lajur, menamakan semula jadual/lajur, dan menukar jenis data lajur.

Artikel ini membandingkan memasang MySQL pada Linux secara langsung berbanding menggunakan bekas podman, dengan/tanpa phpmyadmin. Ia memperincikan langkah pemasangan untuk setiap kaedah, menekankan kelebihan Podman secara berasingan, mudah alih, dan kebolehulangan, tetapi juga

Artikel ini memberikan gambaran menyeluruh tentang SQLite, pangkalan data relasi tanpa server tanpa mandiri. Ia memperincikan kelebihan SQLITE (kesederhanaan, mudah alih, kemudahan penggunaan) dan kekurangan (batasan konkurensi, cabaran skalabiliti). C

Panduan ini menunjukkan pemasangan dan menguruskan pelbagai versi MySQL pada macOS menggunakan homebrew. Ia menekankan menggunakan homebrew untuk mengasingkan pemasangan, mencegah konflik. Pemasangan Butiran Artikel, Permulaan/Perhentian Perkhidmatan, dan PRA Terbaik

Artikel membincangkan mengkonfigurasi penyulitan SSL/TLS untuk MySQL, termasuk penjanaan sijil dan pengesahan. Isu utama menggunakan implikasi keselamatan sijil yang ditandatangani sendiri. [Kira-kira aksara: 159]

Artikel membincangkan alat MySQL GUI yang popular seperti MySQL Workbench dan PHPMyAdmin, membandingkan ciri dan kesesuaian mereka untuk pemula dan pengguna maju. [159 aksara]
