[转]ORA-01555错误总结(一)
原文地址:http://blog.csdn.net/sh231708/article/details/52935695
- SQL语句执行时,需要读取UNDO(前映像数据)来构造CR数据块,完成一致性读取。但是在读取undo前映像数据时发现,undo信息已经被覆盖(undo空间循环使用),不能构造一致性读的CR块,抛出ORA-01555错误
- SQL语句执行时,访问到的数据块,需要进行延迟块清除,但是在进行延迟块清除时,不能确定这个数据块的事务提交时间与SQL执行开始时间的先后次序,从而抛出ORA-01555错误
- 增加UNDO空间,延缓UNDO信息被覆盖,也可以理解为增加undo空间循环使用一次的时间。
- 优化抛出错误的SQL语句,缩短SQL语句执行的时间,也可以避免语句需要访问undo信息被覆盖。
- 避免频繁的提交也是一种可行方法,不过需要改动的量较前两个都要大。提交频率降低后,导致undo 信息被覆盖的可能性也降低了(oracle数据库中未提交的undo是不可能被覆盖),或者undo 事务表被覆盖的可能性也降低了。
Tablespace created.
SQL> ALTER SYSTEM SET undo_tablespace='UNDO1';
System altered.
Connected.
SQL> create table test as select object_id,object_name from dba_objects;
Table created.
SQL> SELECT
2 dbms_rowid.rowid_object(rowid) object_id,
3 dbms_rowid.rowid_relative_fno(rowid) REL_FNO,
4 dbms_rowid.rowid_block_number(rowid) BLOCKNO,
5 dbms_rowid.rowid_row_number(rowid) ROWNO,rowid,object_id,object_name
6 FROM test WHERE object_name='EMP';
OBJECT_ID REL_FNO BLOCKNO ROWNO ROWID OBJECT_ID
---------- ---------- ---------- ---------- ------------------ ----------
OBJECT_NAME
--------------------
73424 4 611 201 AAAR7QAAEAAAAJjADJ 73201
EMP
SQL> select * from test where rowid='AAAR7QAAEAAAAJjADJ';
OBJECT_ID OBJECT_NAME
---------- --------------------
73201 EMP
Block header dump: 0x01000263
Object id on Block? Y
seg/obj: 0x11ed0 csc: 0x00.f3559 itc: 3 flg: E typ: 1 - DATA
brn: 0 bdba: 0x1000201 ver: 0x01 opc: 0
inc: 0 exflg: 0
Itl Xid Uba Flag Lck Scn/Fsc
0x01 0xffff.000.00000000 0x00000000.0000.00 C--- 0 scn
0x0000.000f3559
0x02 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc
0x0000.00000000
0x03 0x0000.000.00000000 0x00000000.0000.00 ---- 0 fsc
0x0000.00000000
SQL> begin
2 open :cur1 for select * from test where rowid='AAAR7QAAEAAAAJjADJ';
3 end;
4 /
PL/SQL procedure successfully completed.
1 row updated.
SQL> select * from test where rowid='AAAR7QAAEAAAAJjADJ';
OBJECT_ID OBJECT_NAME
---------- --------------------
73201 DH
SQL> commit;
Commit complete.
SQL> update test set object_name='DH' where rowid='AAAR7QAAEAAAAJjADJ';
------第二次更新,实验以此为准
1 row updated.
Block header dump: 0x01000263
Object id on Block? Y
seg/obj: 0x11ed0 csc: 0x00.f3a21 itc: 3 flg: E typ: 1 - DATA
brn: 0 bdba: 0x1000201 ver: 0x01 opc: 0
inc: 0 exflg: 0
Itl Xid Uba Flag Lck Scn/Fsc
0x01 0xffff.000.00000000 0x00000000.0000.00 C--- 0 scn
0x0000.000f3559
0x02 0x0010.001.00000004 0x014000d4.0001.2b C---
0 scn 0x0000.000f3a01
0x03 0x0012.003.00000005 0x014000f4.0001.01 ----
1 fsc 0x0000.00000000
bdba: 0x01000263
A transaction identifier consists of:
–Undo segment number
–Transaction table slot number
–Sequence number or wrap#
XID = usn# . slot# . wrap#
A UBA consists of:
–Data block address (DBA) of the
block
–The sequence number of the
block
–The record number within the block
UBA = DBA. seq#. rec#
SQL> select dbms_utility.data_block_address_file(to_number(substr(uba,3,8),'xxxxxxxxxxx'))
undo_file#,
2 dbms_utility.data_block_address_block(to_number(substr(uba,3,8),'xxxxxxxxxxx'))
blockno#,
3 to_number(substr(uba,12,4),'xxxxxxxxx') undo_seq,
4 to_number(substr(uba,17,2),'xxxxxxxxx') undo_record
5 from (select '0x014000f4.0001.01' uba from dual);
UNDO_FILE# BLOCKNO# UNDO_SEQ UNDO_RECORD
---------- ---------- ---------- -----------
5 244 1 1
tab 0, row 201, @0x4e7
tl: 11 fb: --H-FL-- lb:
0x3 cc: 2 --lb:0x3 对应上面的第三个itl事务槽,表示这一被锁定,即session 1中的更新操作导致
col 0: [ 4] c3 08 21 02
col
start_scnw,
2 to_char(start_scnb,'xxxxxxxx') start_scnb, start_scnb+start_scnw*power(2,32)
start_scn
3 from v$transaction;
XIDUSN XIDSLOT XIDSQN UBABLK UBAFIL UBAREC START_SCNW START_SCNB START_SCN
---------- - ---------
---------- ---------- -
---------
----------
---------- ----------
---------
18 3 5 244 5
1 0 f3a22 997922
可以看到xidusn对应xid中的0x0012(十六进制转换为十进制后为18),xidslot对应xid中的003,xidsqn对应xid中的00000005
uba中的5、244、1分别对应UBAFIL、UBABLK、UBAREC
mgc: 0xb000 xts: 0x0068 flg: 0x0001 opt: 2147483646 (0x7ffffffe)
uba: 0x014000f4.0001.01 scn: 0x0000.000f36b8 -----0x014000f4.0001.01对应数据块中ITL中的UBA
Version: 0x01
FREE BLOCK POOL::
uba: 0x00000000.0001.26 ext: 0x0 spc: 0xc6a
uba: 0x00000000.0000.00 ext: 0x0 spc: 0x0
uba: 0x00000000.0000.00 ext: 0x0 spc: 0x0
uba: 0x00000000.0000.00 ext: 0x0 spc: 0x0
uba: 0x00000000.0000.00 ext: 0x0 spc: 0x0
TRN TBL::
index state cflags wrap# uel scn dba parent-xid nub stmt_num
cmt
------------------------------------------------------------------------------------------------
0x00 9 0x00 0x0005 0x0001 0x0000.000f39c4 0x014000f3 0x0000.000.00000000 0x00000001 0x00000000 1399878011
0x01 9 0x00 0x0005 0x0002 0x0000.000f39ce 0x014000f3 0x0000.000.00000000 0x00000001 0x00000000 1399878011
0x02 9 0x00 0x0005 0xffff 0x0000.000f39d7 0x00000000 0x0000.000.00000000 0x00000000 0x00000000 1399878011
0x03 10 0x80 0x0005 0x0000 0x0000.000f3a22 0x014000f4 0x0000.000.00000000 0x00000001 0x00000000 0
0x04 9 0x00 0x0004 0x0005 0x0000.000f3722 0x014000f2 0x0000.000.00000000 0x00000001 0x00000000 1399876988
0x05 9 0x00 0x0004 0x0006 0x0000.000f372d 0x014000f2 0x0000.000.00000000 0x00000001 0x00000000 1399876988
0x06 9 0x00 0x0004 0x0007 0x0000.000f3736 0x014000f2 0x0000.000.00000000 0x00000001 0x00000000 1399876988
....后面的省略.....
UNDO BLK:
xid: 0x0012.003.00000005 seq: 0x1 cnt: 0x1 irb: 0x1 icl: 0x0 flg: 0x0000
Rec Offset Rec Offset Rec Offset Rec Offset
Rec Offset
---------------------------------------------------------------------------
0x01 0x1f64 *-----------------------------* Rec #0x1 slt: 0x03 objn: 73424(0x00011ed0) objd: 73424 tblspc: 4(0x00000004)* Layer: 11 (Row) opc: 1 rci 0x00
Undo type: Regular undo Begin trans Last buffer split: No Temp Object: No
Tablespace Undo: No
rdba: 0x00000000Ext idx: 0
flg2: 0*-----------------------------
uba: 0x014000f3.0001.27 ctl max scn: 0x0000.000f35fb prv tx scn: 0x0000.000f36b8
txn start scn: scn: 0x0000.000f3a22 logon user: 85
prev brb: 20971762 prev bcl: 0
KDO undo record:
KTB Redo
op: 0x03 ver: 0x01
compat bit: 4 (post-11) padding: 1
op: Z
KDO Op code: URP row dependencies Disabled
xtype: XAxtype KDO_KDOM2 flags: 0x00000080 bdba: 0x01000263 hdba: 0x010000aa
itli: 3 ispac: 0 maxfr: 4858
tabn: 0 slot: 201(0xc9) flag: 0x2c lock: 0 ckix: 0
ncol: 2 nnew: 1 size: 0
Vector content:
col 1: [ 2] 44 48 ---根据下面的查询,可以知道保存的前映像数据为‘DH',与我们实验相符SQL> SELECT utl_raw.cast_to_varchar2('4448') from dual;
UTL_RAW.CAST_TO_VARCHAR2('4448')--------------------------------------------------------------------------------
DH
Commit complete.
SQL> create table test1 as select object_id,
object_type from dba_objects;
Table created.
SQL> update test1 set object_type='AAAAAAAAAA' where rownum<100;
99 rows updated.
SQL> /
99 rows updated.
SQL> /
99 rows updated.
SQL> /
99 rows updated.
SQL> /
99 rows updated.
SQL> /
99 rows updated.
SQL> /
99 rows updated.
SQL> /
update test1 set object_type='AAAAAAAAAA' where rownum<100
*
ERROR at line 1:
ORA-30036: unable to extend segment by 8 in undo
tablespace 'UNDO1'
SQL> begin
2 for i in 1..10000 loop
3 update test1 set object_type='xxxxxx' where rownum<3;
4 commit;
5 end loop;
6 end;
7 /
Object id on Block? Y
seg/obj: 0x11ed0 csc: 0x00.f4247 itc: 3 flg: E typ: 1 - DATA
brn: 0 bdba: 0x1000201 ver: 0x01 opc: 0
inc: 0 exflg: 0
Itl Xid Uba Flag Lck Scn/Fsc
0x01 0xffff.000.00000000 0x00000000.0000.00 C--- 0 scn
0x0000.000f3559
0x02 0x0010.001.00000004 0x014000d4.0001.2b C---
0 scn 0x0000.000f3a01
0x03 0x0012.003.00000005 0x014000f4.0001.01 C---
0 scn 0x0000.000f407e
bdba: 0x01000263
xid: 0x0012.001.0000001f seq: 0x7 cnt: 0x3f irb: 0x3f icl: 0x0 flg: 0x0000
Rec Offset Rec Offset Rec Offset Rec Offset
Rec Offset
---------------------------------------------------------------------------
0x01 0x1f60 0x02 0x1f1c 0x03 0x1e74 0x04 0x1dec 0x05 0x1da8
0x06 0x1d00 0x07 0x1c78 0x08 0x1c34 0x09 0x1b8c 0x0a 0x1b04
0x0b 0x1ac0 0x0c 0x1a18 0x0d 0x1990 0x0e 0x194c 0x0f 0x18a4
0x10 0x181c 0x11 0x17d8 0x12 0x1730 0x13 0x16a8 0x14 0x1664
0x15 0x15bc 0x16 0x1534 0x17 0x14f0 0x18 0x1448 0x19 0x13c0
0x1a 0x137c 0x1b 0x12d4 0x1c 0x124c 0x1d 0x1208 0x1e 0x1160
0x1f 0x10d8 0x20 0x1094 0x21 0x0fec 0x22 0x0f64 0x23 0x0f20
0x24 0x0e78 0x25 0x0df0 0x26 0x0dac 0x27 0x0d04 0x28 0x0c7c
0x29 0x0c38 0x2a 0x0b90 0x2b 0x0b08 0x2c 0x0ac4 0x2d 0x0a1c
0x2e 0x0994 0x2f 0x0950 0x30 0x08a8 0x31 0x0820 0x32 0x07dc
0x33 0x0734 0x34 0x06ac 0x35 0x0668 0x36 0x05c0 0x37 0x0538
0x38 0x04f4 0x39 0x044c 0x3a 0x03c4 0x3b 0x0380 0x3c 0x02d8
0x3d 0x0250 0x3e 0x020c 0x3f 0x0164
*-----------------------------
* Rec #0x1 slt: 0x0f objn: 73428(0x00011ed4) objd: 73428 tblspc: 4(0x00000004)
* Layer: 11 (Row) opc: 1 rci 0x00
Undo type: Regular undo Begin trans Last buffer split: No
Temp Object: No
Tablespace Undo: No
rdba: 0x00000000Ext idx: 0
flg2: 0
*-----------------------------
uba: 0x014000f3.0007.31 ctl max scn: 0x0000.000f9d10 prv tx scn: 0x0000.000f9d31
txn start scn: scn: 0x0000.000f9f44 logon user: 85
prev brb: 20971762 prev bcl: 0
KDO undo record:
KTB Redo
op: 0x04 ver: 0x01
compat bit: 4 (post-11) padding: 1
op: L itl: xid: 0x0012.00e.0000001e uba: 0x014000f3.0007.33
flg: C--- lkc: 0
scn: 0x0000.000f9f3c
KDO Op code: LKR row dependencies Disabled
xtype: XA flags: 0x00000000 bdba: 0x0100012b hdba: 0x0100012a
itli: 2 ispac: 0 maxfr: 4858
tabn: 0 slot: 0 to: 0 ---已经不存在session 1中第一个事务的undo信息
ERROR:
ORA-01555: snapshot too old: rollback segment number 18 with name "_SYSSMU18$"
too small
alter system dump undo header '_SYSSMU18$';
alter system dump datafile 5 block 244; 或者 alter system dump
undo block '_SYSSMU18$' xid 18 3 5;
[转]ORA-01555错误总结(一)的更多相关文章
- ORA 00972 错误处理
Oracle 11G SQL 写好的脚本执行后报错:ORA 00972 标识符过长 可能的原因一: select 语句中的字段别名太长,中文字符别名最长为10个汉字,简化别名名称,问题得到解决. 可能 ...
- navicat cannot load oci dll||oracle 改字符集为GBK后 navicat 连不上||Ora-28547 ora net错误
此段适用于 解决 navicat cannot load oci dll 环境 Navicat Premium 和 oracle 原因,navicat 32 和64 都只支持 32位的oci.dll ...
- 关于oracle 11g导出数据时 报 ORA 1455错误的处理
因为导出的该用户的表可能存在空数据表,那么可能就会出现此其异常. 首先: 查看: SQL>show parameter deferred_segment_creation; 假设为T ...
- plsql 连接oralce数据库,报ora 12557 tns 协议适配器不可加载错误
使用plsql 连接oracle 数据库报ora 12557 错误: 解决方案: 1:首先确保服务中的service以及监听器都开启 2:F:\app\Administrator\product\11 ...
- Oracle的常见错误及解决办法
ORA-12528: TNS:listener: all appropriate instances are blocking new connections ORA-12528问题是因为监听中的服务 ...
- 【故障处理】ORA-28040: No matching authentication protocol
[故障处理]ORA-28040: No matching authentication protocol 1.1 BLOG文档结构图 1.2 前言部分 1.2.1 导读和注意事项 各位技术爱好者 ...
- enmo_day_06
RAC Data Guard (DG) EMC NAS SAN 双活 数据完整性 约束 : 主键 : 非空 且 唯一 非空 : 唯一 : 外键 : 检查 : DISABLE, ENABLE VALID ...
- Oracle ORA-01555(快照过旧)
一.引言: [oracle@yft yft]$ oerr ora 01555 01555, 00000, "snapshot too old: rollback segment number ...
- oracle的IMU和ora-01555
IMU: 01555: 按照上图找啊找,已经提交事物的undo块找不到了,就产生01555错误,解决这样问题:1. 确保undo表空间数据的保留时间至少大于最长sql语句的时间 2. 增大undo表空 ...
- RMAN duplicate from active遇到ora-17167,ora-12154
最近在从活动数据库进行异机克隆时碰到了ORA-17629,ORA-17627,ORA-12154的错误,起初以为是一个Bug呢.Oracle Bug着实太多了,已经成了习惯性思维了.汗!错误提示是无法 ...
随机推荐
- Axure谷歌浏览器Chrome扩展程序下载及安装方法
对于很多需要设计产品原型的朋友来说,Axure RP Pro可谓是非常方便.好用的一款软件,因为它不仅能绘制出详细的产品构思,也能生成浏览器格式的产品原型.但是如果想把原型拿给客户查看,千万记得给浏览 ...
- Android 获取闹钟引发的血案
想做一个锁屏的软件.锁屏后可以显示闹钟信息. 一开始的思路是通过android content provider获取 mActivityObject.getContentResolver().quer ...
- PHP实现JS的无符号右移(>>>)
举例: JS: 5>>>2 PHP function uright($a, $n) { $c = 2147483647 >> ($n - 1); return $c &a ...
- 如何使Android应用支持多种屏幕分辨率
原文:http://android.eoe.cn/topic/android_sdk 描述: 让您指定您的应用支持的屏幕的大小并且可以通过屏幕兼容模式来支持比您应用所支持更大的屏幕.所以这对于您需要在 ...
- js正则表达式实现手机号码,密码正则验证
手机号码,密码正则验证. 分享下javascript中正则表达式进行的格式验证,常用的有手机号码,密码等. /** * 手机号码 * 移动:134[0-8],135,136,137,138,139,1 ...
- html5中audio的详细使用
html5的audio功能上已经非常强大,回放,跳转,缓冲等以前只能用flash才能实现的功能,html5的audio都能轻松搞定 最近的一个项目使用到了这个功能,把我使用的情况写下来,供大家参考, ...
- mysql protocol
http://hutaow.com/blog/2013/11/06/mysql-protocol-analysis/ https://dev.mysql.com/doc/internals/en/cl ...
- Angular的重和利
1.第一重:TypeScript,TypeScript语言的特性还是比较丰富的,而且一直在发展,再就是跨语言集成问题,要想Nice对第三方lib做集成,需要自己写d.ts,针对有些第三方库,这件事情有 ...
- Shell脚本判断内容为None的方式
1.判断变量 read -p "input a word :" word if [ ! -n "$word" ] ;then echo "you ha ...
- win2008r2的iis7.5手动建站方法,iis7.5中用独立用户建立网站的方法,提高网站安全性
win2003的iis6手动建站方法,iis6中用独立用户建立网站的方法,提高网站安全性,我们前面的教程有说明,请看http://www.piis.cn/zhishi/web574.asp 现在我们说 ...