|
本帖最后由 guoyJoe 于 2013-3-20 08:46 编辑
我们来看一下NUMBER类型的转储
col 0: [ 2] c2 02 数字100转存后是这样
SQL> select (to_number('2','xxxx')-1)*power(100,to_number('c2','xxxx')-193) from dual;
(TO_NUMBER('2','XXXX')-1)*POWE
------------------------------
100
这样就算回去了
数字-123.333 转存后是
col 0: [ 6] 3d 64 59 59 47 66
select -((101 - to_number('64', 'xxxx')) *
power(100, 62 - to_number('3d', 'xxxx')) +
(101 - to_number('59', 'xxxx')) *
power(100, 62 - to_number('3d', 'xxxx') - 1) +
(101 - to_number('59', 'xxxx')) *
power(100, 62 - to_number('3d', 'xxxx') - 2) +
(101 - to_number('47', 'xxxx')) *
power(100, 62 - to_number('3d', 'xxxx') - 3) )
这样就算回去了
转存后是16进制的
要 改回10进制
创建一个表
SQL> create table t1
2 (it number);
Table created
SQL> insert into t1
2 values(100);
1 row inserted
计算器块
SQL> select rowid from t1;
ROWID
------------------
AAAXKYAABAAAU4aAAA
SQL> select dbms_rowid.rowid_relative_fno('AAAXKYAABAAAU4aAAA'),dbms_rowid.rowid_block_number('AAAXKYAABAAAU4aAAA') from t1;
DBMS_ROWID.ROWID_RELATIVE_FNO( DBMS_ROWID.ROWID_BLOCK_NUMBER(
------------------------------ ------------------------------
1 85530
进行DUMP
SQL> alter system dump datafile 1 block 85530;
System altered
查看其数字的dump格式
flag=--------
ntab=1
nrow=1
frre=-1
fsbo=0x14
fseo=0x1f9a
avsp=0x1f83
tosp=0x1f83
0xe:pti[0] nrow=1 offs=0
0x12:pri[0] offs=0x1f9a
block_row_dump:
tab 0, row 0, @0x1f9a
tl: 6 fb: --H-FL-- lb: 0x1 cc: 1
col 0: [ 2] c2 02 ----这里就是DUMP出来的,长度是2
end_of_block_dump
End dump data blocks tsn: 0 file#: 1 minblk 85530 maxblk 85530
其实这里的C2 02就是其具体的数字。使用DUMP函数也能得出
SQL> select dump(it,16) from t1;
DUMP(IT,16)
--------------------------------------------------------------------------------
Typ=2 Len=2: c2,2
然后通过ORACLE的算法计算回去
SQL> select to_number('c2','xxxx') from dual;
TO_NUMBER('C2','XXXX')
----------------------
194
SQL> select to_number('2','xxxx') from dual;
TO_NUMBER('2','XXXX')
---------------------
2
其实这里的如果换算为10进制是
194,2
如果大于128 就是正数,小于128就是负数
指数是194-193=1
数字位1 是2-1=1*100^(1-0)=100 -1是因为正数+1存储
所以数字也就还原为100
SQL> select (to_number('2','xxxx')-1)*power(100,to_number('c2','xxxx')-193) from dual;
(TO_NUMBER('2','XXXX')-1)*POWE
------------------------------
100
用SQL就是这样,这是第一位
在加入一个负数
SQL> insert into test
2 values(-123.333);
1 row inserted
SQL> commit;
Commit complete
进行DUMP如上
tab 0, row 1, @0x1f90
tl: 10 fb: --H-FL-- lb: 0x2 cc: 1
col 0: [ 6] 3d 64 59 59 47 66
进行计算
Typ=2 Len=6: 3d,64,59,59,47,66
SQL> select dump(it,16) from testpp;
DUMP(IT,16)
--------------------------------------------------------------------------------
Typ=2 Len=2: c2,2
Typ=2 Len=6: 3d,64,59,59,47,66 --66 及10进制的102是一个排序位不用理会,用在负数的时候
内部存储长度6 指数3d 后面数数字位
换算为10进制就是
61,100,89,89,71,102
61是指数未
102 是排序位
中间的数字位
select -((101 - to_number('64', 'xxxx')) *
power(100, 62 - to_number('3d', 'xxxx')) +
(101 - to_number('59', 'xxxx')) *
power(100, 62 - to_number('3d', 'xxxx') - 1) +
(101 - to_number('59', 'xxxx')) *
power(100, 62 - to_number('3d', 'xxxx') - 2) +
(101 - to_number('47', 'xxxx')) *
power(100, 62 - to_number('3d', 'xxxx') - 3) )
from dual;
这样数字就完成了转换。
|
|