Rumah pangkalan data tutorial mysql ORA-01291: missing logfile 事务闪回缺失日志

ORA-01291: missing logfile 事务闪回缺失日志

Jun 07, 2016 pm 02:50 PM
missing hal ehwal kilat

实验遇到的问题: 1、刚开始做前面的实验的时候,resetlogs重置了联机日志,导致闪回的时候总是报miss logfile的错误。 这个时候需要用noretlogs的方式重建控制文件,然后重新启动数据库到open状态。 SQL SELECT distinct xid,commit_scn FROM flashback_tran

实验遇到的问题:
1、刚开始做前面的实验的时候,resetlogs重置了联机日志,导致闪回的时候总是报miss logfile的错误。
这个时候需要用noretlogs的方式重建控制文件,然后重新启动数据库到open状态。
SQL> SELECT distinct xid,commit_scn FROM flashback_transaction_query t
  2  where table_owner='HR'
  3  and   lower(t.table_name) = 'employees'
  4  and   t.commit_timestamp > systimestamp - interval '90' minute
  5  order by t.commit_scn ;
XID              COMMIT_SCN
---------------- ----------
100004005E010000    2948380
0E0019005E010000    2948386

SQL> declare
  2  xids sys.xid_array ;
  3  begin
  4    xids := sys.xid_array('100004005E010000');
  5    dbms_flashback.transaction_backout(1,xids,options => dbms_flashback.cascade);
  6  end ;
  7  /
declare
*
ERROR at line 1:
ORA-55507: Encountered mining error during Flashback Transaction Backout.
function:krvxpsr
ORA-01291: missing logfile
ORA-06512: at "SYS.DBMS_FLASHBACK", line 37
ORA-06512: at "SYS.DBMS_FLASHBACK", line 70
ORA-06512: at line 5
此问题是我之前启动数据库时候重置了日志文件,导致数据库不读日志。需要重建控制文件。

shutdown immediate
startup nomount
alter database backup controlfile to trace as 'J:\app\wufan\diag\rdbms\orcl\orcl\trace\control.trac';
CREATE CONTROLFILE REUSE DATABASE "ORCL" NORESETLOGS  ARCHIVELOG
    MAXLOGFILES 16
    MAXLOGMEMBERS 3
    MAXDATAFILES 100
    MAXINSTANCES 8
    MAXLOGHISTORY 292
LOGFILE
  GROUP 1 'J:\APP\WUFAN\ORADATA\ORCL\REDO01.LOG'  SIZE 50M BLOCKSIZE 512,
  GROUP 2 'J:\APP\WUFAN\ORADATA\ORCL\REDO02.LOG'  SIZE 50M BLOCKSIZE 512,
  GROUP 3 'J:\APP\WUFAN\ORADATA\ORCL\REDO03.LOG'  SIZE 50M BLOCKSIZE 512
-- STANDBY LOGFILE


DATAFILE
  'J:\APP\WUFAN\ORADATA\ORCL\SYSTEM01.DBF',
  'J:\APP\WUFAN\ORADATA\ORCL\SYSAUX01.DBF',
  'J:\APP\WUFAN\ORADATA\ORCL\UNDOTBS02.DBF',
  'J:\APP\WUFAN\ORADATA\ORCL\USERS01.DBF',
  'J:\APP\WUFAN\ORADATA\ORCL\EXAMPLE01.DBF',
  'J:\APP\WUFAN\ORADATA\ORCL\UNDOTBS04.DBF',
  'J:\APP\WUFAN\ORADATA\ORCL\DATAFILE\O1_MF_UNDOTBS4_CK602RTP_.DBF',
  'J:\APP\WUFAN\ORADATA\ORCL\DATAFILE\O1_MF_TEST02_CK610HG8_.DBF',
  'J:\APP\WUFAN\ORADATA\ORCL\DATAFILE\O1_MF_TEST02_CK611OKD_.DBF',
  'J:\APP\WUFAN\ORADATA\ORCL\DATA_TEST01.BDF',
  'J:\APP\WUFAN\ORADATA\ORCL\HEAT01.BDF'
CHARACTER SET ZHS16GBK
;
--这种情况其实不需要恢复,你执行了这条命令它会告诉你没有什么可恢复的。
RECOVER DATABASE;
--打开所有的补充日志文件,可以不做
ALTER DATABASE ADD SUPPLEMENTAL LOG DATA;
--打开系统归档,当前已经是归档状态,所以这条命令会报错,不用管
ALTER SYSTEM ARCHIVE LOG ALL;
--打开数据库
ALTER DATABASE OPEN;
至此,重建控制文件已经完成

重新进行试验
1、开两个事物
SQL> update hr.employees t
  2  set t.salary = t.salary * 2 ;
107 rows updated.
SQL> commit ;
Commit complete.
SQL> update hr.employees t
  2  set t.salary = t.salary * 1.1 ;
107 rows updated.
SQL> commit ;
Commit complete.
2、查询两个事物号
SQL> SELECT distinct xid,commit_scn FROM flashback_transaction_query t
  2  where table_owner='HR'
  3  and   lower(t.table_name) = 'employees'
  4  and   t.commit_timestamp > systimestamp - interval '15' minute
  5  order by t.commit_scn ;
XID              COMMIT_SCN
---------------- ----------
13001A0061010000    2983670
0F0021005D010000    2983677
3、执行事物闪回
SQL> declare
  2  xids sys.xid_array ;
  3  begin
  4    xids := sys.xid_array('13001A0061010000');
  5    dbms_flashback.transaction_backout(1,xids,options => dbms_flashback.nocascade);
  6  end ;
  7  /
declare
*
ERROR at line 1:
ORA-00600: internal error code, arguments: [ktgRunStmt_5], [25153], [ORA-25153:
Temporary Tablespace is Empty
ORA-00600: internal error code, arguments: [ktgRunStmt_5], [25153], [ORA-25153:
Temporary Tablespace is Empty
], [], [], [], [], [], [], [], [], []
], [], [], [], [], [], [], [], [], []
ORA-00600: internal error code, arguments: [ktgRunStmt_5], [25153], [ORA-25153:
Temporary Tablespace is Empty
], [], [], [], [], [], [], [], [], []
ORA-06512: at "SYS.DBMS_FLASHBACK", line 37
ORA-06512: at "SYS.DBMS_FLASHBACK", line 70
ORA-06512: at line 5
看着报错多吓人!其实问题就在于
[ORA-25153:
Temporary Tablespace is Empty
临时表空间是空的。下面就来确认这个问题:
--当前用户默认临时表空间
SQL> select username,temporary_tablespace from dba_users where username='SYS';
USERNAME                       TEMPORARY_TABLESPACE
------------------------------ ------------------------------
SYS                            TEMP_01
--默认表空间逻辑上是联机的,没问题
SQL> select tablespace_name,status from dba_tablespaces where tablespace_name='TEMP_01';
TABLESPACE_NAME                STATUS
------------------------------ ---------
TEMP_01                        ONLINE
--物理上没有文件,问题就在这儿
SQL> select file_name,tablespace_name from dba_temp_files;
no rows selected
--确定临时文件是存在的,把该临时文件添加到表空间
SQL> alter tablespace temp add tempfile 'J:\app\wufan\oradata\orcl\temp01.dbf';
Tablespace altered.
--上面那条语句把文件对应到temp表空间了,其实sys的默认临时表空间是temp_01。
SQL> select tablespace_name,file_name from dba_temp_files;
TABLESPACE_NAME
------------------------------
FILE_NAME
--------------------------------------------------------------------------------
TEMP
J:\APP\WUFAN\ORADATA\ORCL\TEMP01.DBF
--将错就错吧,就将sys默认表空间改成temp吧
SQL> alter user sys temporary tablespace temp;
User altered.
--查看是否改过来了
SQL> select username,temporary_tablespace from dba_users where username='SYS';
USERNAME                       TEMPORARY_TABLESPACE
------------------------------ ------------------------------
SYS                            TEMP
重新进行实验:
开启连个事务:
--这边报了个错,因为做了很多次实验,现在这个薪水的值已经很大了,超出了字段的长度
SQL> update hr.employees t
  2  set t.salary = t.salary * 2 ;
set t.salary = t.salary * 2
                        *
ERROR at line 2:
ORA-01438: value larger than specified precision allowed for this column

SQL> commit ;
Commit complete.
SQL> update hr.employees t
  2  set t.salary = t.salary * 1.1 ;
107 rows updated.
SQL> commit ;
Commit complete.
--因为失败了一个语句,所以查询就只有3个事务。
SQL> SELECT distinct xid,commit_scn FROM flashback_transaction_query t
  2  where table_owner='HR'
  3  and   lower(t.table_name) = 'employees'
  4  and   t.commit_timestamp > systimestamp - interval '15' minute
  5  order by t.commit_scn ;
XID              COMMIT_SCN
---------------- ----------
13001A0061010000    2983670
0F0021005D010000    2983677
0D00050064010000    2984032
--执行回退到倒数第二个事务,用nocascade
SQL> declare
  2  xids sys.xid_array ;
  3  begin
  4    xids := sys.xid_array('0F0021005D010000');
  5    dbms_flashback.transaction_backout(1,xids,options => dbms_flashback.nocascade);
  6  end ;
  7  /
declare
*
ERROR at line 1:
ORA-55504: Transaction conflicts in NOCASCADE mode
ORA-06512: at "SYS.DBMS_FLASHBACK", line 37
ORA-06512: at "SYS.DBMS_FLASHBACK", line 70
ORA-06512: at line 5
--失败了,因为倒数第二个事务依赖于倒数第一个事务
--重新用cascade选项,把倒数第二个事务依赖的第一个事务一起回退掉
SQL> declare
  2  xids sys.xid_array ;
  3  begin
  4    xids := sys.xid_array('0F0021005D010000');
  5    dbms_flashback.transaction_backout(1,xids,options => dbms_flashback.cascade);
  6  end ;
  7  /
PL/SQL procedure successfully completed.
--过程执行成功,但是别忘了commit,oracle在过程里面并没有提交,需要你手动提交才能生效
SQL> commit ;
Commit complete.
SQL>




Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Tamat masa menunggu kunci melebihi; cuba mulakan semula transaksi - Cara menyelesaikan ralat MySQL: tamat masa menunggu transaksi Tamat masa menunggu kunci melebihi; cuba mulakan semula transaksi - Cara menyelesaikan ralat MySQL: tamat masa menunggu transaksi Oct 05, 2023 am 08:46 AM

Lockwaittimeoutceeded;tryrestartingtransaction - Cara menyelesaikan ralat MySQL: transaction wait timeouts Apabila menggunakan pangkalan data MySQL, kadangkala anda mungkin menghadapi ralat biasa: Lockwaittimeoutexceeded;tryrestartingtransaction. Ralat ini biasanya berlaku apabila

Apakah yang perlu saya lakukan jika bar tugas komputer saya terus berkelip dan skrin hitam apabila saya memulakan Windows 7? Apakah yang perlu saya lakukan jika bar tugas komputer saya terus berkelip dan skrin hitam apabila saya memulakan Windows 7? Jul 12, 2023 am 10:49 AM

Saya tidak tahu jika mana-mana daripada anda menghadapi masalah bahawa bar tugas terus berkelip dan komputer membeku apabila anda memulakan komputer anda Apakah yang perlu anda lakukan jika bar tugas terus berkelip dan skrin hitam apabila anda memulakan win7? Jika anda tidak tahu bagaimana untuk menyelesaikannya, lihat cara di bawah. .Apa yang perlu dilakukan jika bar tugas terus berkelip dan skrin hitam apabila Windows 7 dimulakan 1. Apabila menghadapi situasi ini, klik tetikus pada ikon bar tugas di bawah dan pilih untuk menjalankan pengurus tugas dalam kotak dialog pop timbul? . 2. Selepas memasukkan pengurus tugas, halaman pengurus tugas akan muncul. 3. Pilih pilihan fail pada halaman Pengurus Tugas dan klik Cipta Tugas. 4. Selepas memasukkan tugas yang baru dibuat, taip explorer.exe, dan kemudian klik OK, supaya ia akan muncul pada desktop.

Pemprosesan transaksi MySQL: perbezaan antara penyerahan automatik dan penyerahan manual Pemprosesan transaksi MySQL: perbezaan antara penyerahan automatik dan penyerahan manual Mar 16, 2024 am 11:33 AM

Pemprosesan transaksi MySQL: perbezaan antara penyerahan automatik dan penyerahan manual Dalam pangkalan data MySQL, urus niaga ialah satu set penyata SQL sama ada semua pelaksanaan berjaya atau semua pelaksanaan gagal, memastikan ketekalan dan integriti data. Dalam MySQL, urus niaga boleh dibahagikan kepada penyerahan automatik dan penyerahan manual Perbezaannya terletak pada masa penyerahan transaksi dan skop kawalan ke atas transaksi. Berikut akan memperkenalkan perbezaan antara penyerahan automatik dan penyerahan manual secara terperinci, dan memberikan contoh kod khusus untuk digambarkan. 1. Hantar secara automatik dalam MySQL, jika ia tidak dipaparkan

bootmgr tiada dan tidak boleh boot bootmgr tiada dan tidak boleh boot Feb 20, 2024 pm 04:33 PM

bootmgr ialah singkatan program pengurusan but, yang merupakan salah satu komponen utama untuk permulaan sistem pengendalian Windows. Apabila anda memulakan komputer, jika mesej ralat "bootmgrismissing" muncul, ini bermakna komputer tidak dapat mencari fail yang diperlukan untuk permulaan. Masalah ini boleh disebabkan oleh pelbagai sebab, seperti kegagalan cakera keras, fail but rosak atau isu persediaan. Di bawah ini kami akan meneroka kemungkinan penyelesaian untuk menyelesaikan isu ini. Penyelesaian 1: Periksa peranti but Mula-mula, kita perlu pastikan

Mengapa desktop terus berkelip selepas kemas kini win11 dan cara membetulkannya Mengapa desktop terus berkelip selepas kemas kini win11 dan cara membetulkannya Jul 01, 2023 pm 02:54 PM

Mengapakah desktop terus berkelip selepas kemas kini win11 Bagaimana untuk membetulkannya? Baru-baru ini, sesetengah pengguna mendapati bahawa selepas mengemas kini dan menaik taraf sistem Windows 11 mereka, desktop terus menyegarkan, menyebabkan skrin kelihatan sentiasa berkelip dan tidak dapat digunakan secara normal sepenuhnya. Jadi mengapa desktop terus berkelip selepas kemas kini win11? Bagaimana untuk menyelesaikannya? Oleh itu, hari ini editor akan membawa anda penyelesaian kepada masalah sentiasa menyegarkan skrin percikan selepas peningkatan win11, sila lihat. Penyelesaian kepada skrin percikan yang terus menyegarkan selepas naik taraf Win11 Penyelesaian 1. Laraskan tetapan 1. Sebab yang paling mungkin ialah kemas kini telah menghidupkan perkhidmatan lalai tertentu. Tekan kekunci pintasan "win+R" untuk membuka kotak dialog run, masukkan "servic" dalam kotak

Kuasai kuasa PHP PDO: pertanyaan lanjutan dan kemas kini Kuasai kuasa PHP PDO: pertanyaan lanjutan dan kemas kini Feb 20, 2024 am 08:24 AM

Sambungan Objek Data PHP (PDO) menyediakan interaksi yang cekap dan berorientasikan objek dengan pelayan pangkalan data. Keupayaan pertanyaan dan kemas kini lanjutannya membolehkan pembangun melaksanakan operasi pangkalan data yang kompleks, meningkatkan prestasi dan kebolehselenggaraan kod. Artikel ini akan menyelidiki pertanyaan lanjutan dan fungsi kemas kini PDO dan membimbing anda untuk menguasai fungsinya yang berkuasa. Pertanyaan lanjutan: Menggunakan ruang letak dan parameter terikat Ruang letak dan parameter terikat ialah alat penting untuk meningkatkan prestasi pertanyaan dan keselamatan. Pemegang tempat menggunakan tanda soal (?) untuk mewakili parameter yang boleh diganti dalam pertanyaan, manakala parameter bind membolehkan anda menentukan jenis data dan nilai setiap parameter. Dengan menggunakan kaedah ini, anda boleh mengelakkan serangan suntikan SQL dan meningkatkan prestasi kerana enjin pangkalan data boleh mengoptimumkan pertanyaan lebih awal daripada masa. //Gunakan pemegang tempat $stmt=$

Tutorial PHP PDO: Panduan Lanjutan daripada Asas kepada Penguasaan Tutorial PHP PDO: Panduan Lanjutan daripada Asas kepada Penguasaan Feb 19, 2024 pm 06:30 PM

1. Pengenalan kepada PDO PDO ialah perpustakaan sambungan PHP, yang menyediakan cara berorientasikan objek untuk mengendalikan pangkalan data. PDO menyokong pelbagai pangkalan data, termasuk Mysql, postgresql, oracle, SQLServer, dll. PDO membolehkan pembangun menggunakan API bersatu untuk mengendalikan pangkalan data yang berbeza, yang membolehkan pembangun bertukar dengan mudah antara pangkalan data yang berbeza. 2. PDO menyambung ke pangkalan data Untuk menggunakan PDO untuk menyambung ke pangkalan data, anda perlu mencipta objek PDO terlebih dahulu. Pembina objek PDO menerima tiga parameter: jenis pangkalan data, nama hos, nama pengguna pangkalan data dan kata laluan. Sebagai contoh, kod berikut mencipta objek yang bersambung ke pangkalan data mysql: $dsn="mysq

Apakah teknik pemprosesan transaksi untuk mempelajari MySQL? Apakah teknik pemprosesan transaksi untuk mempelajari MySQL? Jul 30, 2023 pm 10:13 PM

Apakah teknik pemprosesan transaksi untuk mempelajari MySQL? Pengenalan: Transaksi adalah konsep yang sangat penting dalam sistem pengurusan pangkalan data Ia menyediakan mekanisme untuk memastikan integriti dan konsistensi data. Dalam MySQL, transaksi ialah unit pelaksanaan set pernyataan SQL, yang boleh memastikan bahawa semua pernyataan SQL dalam set pernyataan ini sama ada berjaya dilaksanakan atau digulung semula jika semua pelaksanaan gagal. Artikel ini akan memperkenalkan kemahiran pemprosesan transaksi pembelajaran MySQL dan memberikan contoh kod yang sepadan. Mulakan transaksi: Dalam MySQL, anda boleh menggunakan BEGIN dan STARTTRAN

See all articles