亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

創建表時考慮列的順序

2024-07-21 02:40:22
字體:
來源:轉載
供稿:網友

  創建表時考慮列的順序
創建一個表時表中列的順序在某些程度上對性能會有一定的影響.(表中的列有數據)
Oracle對行數據的存儲結構ROW HEADER(行頭)和COLUMN DATA(列數據).ROW HEADER存儲的信息是一個FLAG BYTE,一個LOCK BYTE 和COLUMN 
COUNT.COLUMN DATA包含COLUMN LENGTH和COLUMN DATA
關于這些我們可以DUMP個表做一下測試
create test as select * from dba_objects;
select header_file,header_block from dba_segments where owner=’TEST’ and segment_name=’TEST’;
HEADER_FILE    HEADER_BLOCK
------------------------   ---------------------------
                   13                      1179
alter system dump datafile 13 block 1180
得出來的文件在UDUMP中.我們查看如下信息
block_row_dump:
tab 0, row 0, @0x1f20
tl: 96 fb: --H-FL-- lb: 0x0  cc: 13--------row header信息.
col  0: [ 3]  53 59 53-------------------COLUMN DATA
fb: --H-FL-- 是FLAG BYTE.  
fb Flag Byte: 
K = Cluster Key (Flags may change meaning if this is set to show HASH cluster) 
C = Cluster table member 
H = Head piece of row 
D = Deleted row 
F = First data piece 
L = Last data piece 
P = First column continues from PRevious piece 
N = Last column continues in next piece
lb: 0x0-----------LOCK BYTE,鎖信息
cc: 13------------COLUMN COUNT
col  0---------第一列
[ 3]-------------COLUMN LENGTH
  53 59 53---------實際數據
這里一些信息可以參考grassbell寫的文章<<偷窺Data block 的物理結構>>.對每一個列,在每一個列數據前都含有列長度.在做查詢時,查詢行中某個
列的值,Oracle首先做的是檢查這些相關列的長度位.這個操作比較快而且效率較高.但是假如反復頻繁的這樣子做還是會帶來性能方面的影響.
下面的例子中創建了一個有10列的表并插入數據.
先設置DB_BLOCK_SIZE=2K(用參數設置,在這里設置為這個只是為了測試方便)
SQL> create table small (
  2    n0 number,
  3    n1 number,
  4   
 n2 number,
  5    n3 number,
  6    n4 number,
  7    n5 number,
  8    n6 number,
  9    n7 number,
 10    n8 number,
 11    n9 number
 12  ) pctfree 0;
Table created.
SQL> begin
  2    for i in 1..78 loop
  3      insert into small values (0,0,0,0,0,0,0,0,0,0);
  4    end loop;
  5  end;
  6  /
PL/SQL procedure sUCcessfully completed.
SQL> set timing on
SQL> declare
  2    n number;
  3  begin
  4    for i in 1..1000000 loop
  5      select sum(n0) into n from small;
  6    end loop;
  7  end;
  8  /
PL/SQL procedure successfully completed.
Elapsed: 00:07:437.30
SQL> declare
  2    n number;
  3  begin
  4    for i in 1..1000000 loop
  5      select sum(n9) into n from small;
  6    end loop;
  7  end;
  8  /
PL/SQL procedure successfully completed.
Elapsed: 00:08:482.13
從上面的例子很明顯可以看到在一個表中做查詢時,查詢的數據和列的屬性都是一樣的,但是所查的列位于第一列時查詢速度比在第10快了差不多
10%.所以在建表的時候規則就是根據應用將表中經常訪問的列放面前面.建表時一般都有一個PRIMARY KEY的列,像這種屬性的列一般我們直接訪
問的并不多.所以我們一般不放在第一列.關于這個其實假如我們有注重到的話,Oracle本身字典內表也是這樣子的.
desc dba_objects看看.或者其他的表可以試試.
還有另外一個要考慮的列的位置的就是列中含有較多的NULL值時所要放的位置.
Oracle存儲NULL值時,一行中某個列存在NULL值,而這一列的后面的列中存在有數據(非NULL),則Oracle會分配1byte來存放NULL.假如這一列的后面
沒有列或者都是NULL值時.這一列和后面的NULL值Oracle都不做存儲.列信息也不存儲.這一點可以看以下例子.
SQL> create table null_order (
  2    column1 number,
  3    column2 number,
  4    column3 number
  5  );
Table created.
SQL> insert into null_order (column2) values 
(0);
1 row created.
SQL> select header_file, header_block from dba_segments
  2  where segment_name = ’TEST’ and owner = ’TEST’;
HEADER_FILE HEADER_BLOCK
----------- ------------
          3        50010
SQL> alter system dump datafile 3 block 50011;
System altered.
然后查看DUMP出來的文件的相關信息
block_row_dump:
tab 0, row 0, @0x7b2
tl: 6 fb: --H-FL-- lb: 0x1 cc: 2
col  0: *NULL*--------------第一列的NULL
col  1: [ 1]  80----------------第二列的值(后面沒有了第三列的值)
end_of_block_dump
結論:創建一個表時,可以將我們經常訪問到的列放在表的前面.一般很少直接SELECT出來的PRIMARY KEY列可以放到中間來.列中假如可能會含有
較多NULL值的列可以放在最后面.可以終合考慮上面兩點,根據系統的應用做相應操作.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久999成人| zzjj国产精品一区二区| 欧美黑人国产人伦爽爽爽| 日韩av中文字幕在线免费观看| 欧美怡红院视频一区二区三区| 国产精品丝袜一区二区三区| 久久久久久久久久久av| 欧美精品videossex88| 亚洲精品wwwww| 亚洲高清免费观看高清完整版| 亚洲国产精品一区二区久| 欧美中文字幕在线播放| 精品在线观看国产| 在线一区二区日韩| 久久国产一区二区三区| 91免费观看网站| 亚洲无亚洲人成网站77777| 国产成人精品免高潮在线观看| 亚洲天堂av图片| 国产成人福利夜色影视| 日韩激情在线视频| 中文日韩电影网站| 欧美高清自拍一区| 欧美老少做受xxxx高潮| 91精品免费看| 日韩女优人人人人射在线视频| 成人羞羞国产免费| 日韩亚洲国产中文字幕| 日韩精品中文字| 国产日韩欧美夫妻视频在线观看| 亚洲二区在线播放视频| 日韩av综合网站| 亚洲第一视频在线观看| 91精品啪在线观看麻豆免费| 久久电影一区二区| 日韩美女免费线视频| 欧美日韩国产123| 日韩成人av网址| 欧美激情久久久| 尤物九九久久国产精品的特点| 日韩毛片在线看| 在线丨暗呦小u女国产精品| 69久久夜色精品国产69| 亚洲精品99久久久久中文字幕| 亚洲在线免费看| 国产精品久久久久久久久久久新郎| 亚洲精品国产综合区久久久久久久| 91精品国产成人www| 久久久久久久爱| 日本精品在线视频| 亚洲色图校园春色| 亚洲精品小视频在线观看| 庆余年2免费日韩剧观看大牛| 欧美激情视频网址| 中文字幕自拍vr一区二区三区| 亚洲成人激情在线| 欧美成人h版在线观看| 国产精品亚发布| 中日韩美女免费视频网站在线观看| 久久久久久久影视| 欧美裸体xxxx极品少妇| 日韩电影免费观看中文字幕| 亚洲老头同性xxxxx| 精品国产一区二区三区久久狼5月| 成人深夜直播免费观看| 久久久精品999| 久久久久久久影视| 亚洲福利视频免费观看| 热门国产精品亚洲第一区在线| 亚洲自拍在线观看| 国产suv精品一区二区三区88区| 96国产粉嫩美女| 日韩电影免费观看在线| 亚洲尤物视频网| 欧美激情精品久久久| 国产精品日韩在线播放| 国产精品久久久久久久午夜| 亚洲第一精品自拍| 日韩成人免费视频| 亚洲摸下面视频| 国产精品第二页| 自拍偷拍亚洲在线| 日韩一级裸体免费视频| 成人激情视频在线| 一本色道久久88综合日韩精品| 久久精品美女视频网站| 亚洲精品成人网| 国产精品96久久久久久| 久久亚洲欧美日韩精品专区| 国产精品自产拍高潮在线观看| 欧美精品激情在线观看| 91av在线免费观看| 国产精品久久77777| 亚洲综合成人婷婷小说| 久久久黄色av| 欧美激情欧美狂野欧美精品| 日韩有码在线电影| 国产精品欧美一区二区三区奶水| 国产精品va在线| 国产情人节一区| 欧美性高潮床叫视频| 久久天天躁夜夜躁狠狠躁2022| 日韩美女在线播放| 18久久久久久| 亚洲精品丝袜日韩| 综合136福利视频在线| 色综合色综合网色综合| 日韩中文在线观看| 最近中文字幕日韩精品| 国产91ⅴ在线精品免费观看| 45www国产精品网站| 国产成人亚洲综合91精品| 亚洲精品第一页| 国产精品无码专区在线观看| 97视频在线看| 国产亚洲精品美女久久久久| 日韩精品视频在线免费观看| 日韩成人中文字幕| 在线看福利67194| 国产精品久久久久免费a∨| 亚洲美女精品久久| 7777免费精品视频| 欧美激情免费在线| 久久精品99久久久香蕉| 韩国精品久久久999| 国产视频久久网| 国产综合福利在线| 性色av香蕉一区二区| 久久综合伊人77777蜜臀| 欧美激情中文字幕在线| 精品亚洲夜色av98在线观看| 欧美丝袜一区二区三区| 欧美另类99xxxxx| 国产精品一区二区在线| 欧美在线性爱视频| 久久噜噜噜精品国产亚洲综合| www欧美日韩| 92看片淫黄大片欧美看国产片| 日本久久久久久久久| 亚洲天堂av综合网| www.国产一区| 欧美激情一区二区三区成人| 亚洲福利在线视频| 精品久久久久国产| 国产精品香蕉国产| 国产精品视频网址| 欧美黄网免费在线观看| 日韩在线播放视频| 亚洲第一视频在线观看| 亚洲福利小视频| 成人精品一区二区三区电影免费| 亚洲成人黄色在线观看| 日韩免费精品视频| 久久亚洲综合国产精品99麻豆精品福利| 亚洲一级免费视频| www.欧美免费| 秋霞午夜一区二区| 国产99久久精品一区二区 夜夜躁日日躁| 欧美午夜女人视频在线| 欧美视频国产精品| 亚洲人成电影在线播放| 久久久精品久久久| 亚洲国产精品yw在线观看| 2021久久精品国产99国产精品|