[20171218]varchar2(4000)如何保存.txt--//以前寫的,不知道為什麼被刪除了,現在補上.如果一行能被存儲於一個數據塊(data block)中,那麼其行頭(row header)所需容量將不少於 3 位元組(byte)。在行頭信息之後依次儲存的是各列的列長(column le ...
[20171218]varchar2(4000)如何保存.txt
--//以前寫的,不知道為什麼被刪除了,現在補上.
如果一行能被存儲於一個數據塊(data block)中,那麼其行頭(row header)所需容量將不少於 3 位元組(byte)。在行頭信息之後依次
儲存的是各列的列長(column length)及列值(column value)。列長存儲於列值之前,如列值不超過250 位元組,那麼 Oracle使用1位元組存
儲其列長;如列值超過 250 位元組,則使用 3 位元組存儲其列長。列數據(column data)所需的存儲空間取決於此列的數據類型(datatype)。
如果某列的數據類型為變長(variable length)的,那麼存儲此列值所需的空間可能會隨著數據更新而增長或縮小。
--//測試看看oracle如何存儲列值超過250位元組的.
1.建立測試:
SCOTT@book> @ &r/ver1
PORT_STRING VERSION BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx 11.2.0.4.0 Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
SCOTT@book> create table t1(v1 varchar2(4000));
Table created.
insert into t1 values(rpad('1',250,'A'));
insert into t1 values(rpad('2',251,'B'));
insert into t1 values(rpad('2',4000,'C'));
commit ;
SCOTT@book> select rowid,substr(v1,1,2) from t1;
ROWID SUBS
------------------ ----
AAAWJvAAEAAAAIkAAA 1A
AAAWJvAAEAAAAIkAAB 2B
AAAWJvAAEAAAAIkAAC 2C
SCOTT@book> @ &r/rowid AAAWJvAAEAAAAIkAAA
OBJECT FILE BLOCK ROW ROWID_DBA DBA TEXT
---------- ---------- ---------- ---------- -------------------- -------------------- ----------------------------------------
90735 4 548 0 0x1000224 4,548 alter system dump datafile 4 block 548 ;
SCOTT@book> alter system checkpoint;
System altered.
2.使用bbed查看:
BBED> set dba 4,548
DBA 0x01000224 (16777764 4,548)
BBED> x /rc *kdbr[0]
rowdata[4263] @7934
-------------
flag@7934: 0x2c (KDRHFL, KDRHFF, KDRHFH)
lock@7935: 0x01
cols@7936: 1
col 0[250] @7937: 1AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA...(太長,截去)
BBED> dump /v count 64
File: /mnt/ramdisk/book/users01.dbf (4)
Block: 548 Offsets: 7934 to 7997 Dba:0x01000224
-----------------------------------------------------------------------------------------------------------
2c0101fa 31414141 41414141 41414141 41414141 41414141 41414141 41414141 l ,...1AAAAAAAAAAAAAAAAAAAAAAAAAAA
41414141 41414141 41414141 41414141 41414141 41414141 41414141 41414141 l AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
<32 bytes per line>
--//2c 表示flag,01 表示lock ,01 表示 cols. 0xfa= 250.長度<=250,Oracle使用1位元組存儲其列長.繼續看下麵的記錄:
BBED> x /rc *kdbr[1]
rowdata[4006] @7677
-------------
flag@7677: 0x2c (KDRHFL, KDRHFF, KDRHFH)
lock@7678: 0x01
cols@7679: 1
col 0[251] @7680: 2BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB ...(snip..)
BBED> dump /v count 64
File: /mnt/ramdisk/book/users01.dbf (4)
Block: 548 Offsets: 7677 to 7740 Dba:0x01000224
-----------------------------------------------------------------------------------------------------------
2c0101fe fb003242 42424242 42424242 42424242 42424242 42424242 42424242 l ,.....2BBBBBBBBBBBBBBBBBBBBBBBBB
42424242 42424242 42424242 42424242 42424242 42424242 42424242 42424242 l BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB
<32 bytes per line>
--//前面2c0101 不再描述.0xfe=254 ,使用fe表示超過長度250. 後面0x00fb(倒過來)=251表示字元串長度.繼續看:
BBED> x /rc *kdbr[2]
rowdata[0] @3671
----------
flag@3671: 0x2c (KDRHFL, KDRHFF, KDRHFH)
lock@3672: 0x01
cols@3673: 1
col 0[4000] @3674: 2CCCCCCCCCCCCCCCCCCCCCCCCCCCCCC.... (snip)
BBED> dump /v count 64
File: /mnt/ramdisk/book/users01.dbf (4)
Block: 548 Offsets: 3671 to 3734 Dba:0x01000224
-----------------------------------------------------------------------------------------------------------
2c0101fe a00f3243 43434343 43434343 43434343 43434343 43434343 43434343 l ,.....2CCCCCCCCCCCCCCCCCCCCCCCCC
43434343 43434343 43434343 43434343 43434343 43434343 43434343 43434343 l CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
<32 bytes per line>
--//0xfe=254 ,使用fe表示超過長度250. 後面0x0fa0(倒過來)=4000,表示字元串長度.
SCOTT@book> @ &r/16to10 0fa0
16 to 10 DEC
------------
4000
總結:
1.如果列值長度小於等於250位元組,Oracle使用1位元組存儲其列長.內容為欄位的長度.
2.如果列值長度超過250位元組,則使用3位元組存儲其列長。前面1個位元組使用0xfe(表示超過250),後面2個位元組表示列值長度.