日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

Oracle学习(1)——BLOCK

發(fā)布時(shí)間:2023/12/31 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Oracle学习(1)——BLOCK 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

BLOCK

BLOCK是ORACLE下I/O的最小單位(換句話說(shuō),一次讀出的數(shù)據(jù)至少是一個(gè)BLOCk)。 ORACLE的BLOCk是由一個(gè)或多個(gè)OS BLOCk組成的。 ORACLE的BLOCK是在創(chuàng)建TABLESPACE的時(shí)候就劃分好的,之后分配使用。 ORACLE的初始化參數(shù)DB_BLOCK_SIZE就是指定BLOCK大小的。? BLOCK的結(jié)構(gòu):HEADER, FREE SPACE , DATA SPACE。 HEADER部分和DATA SPACE從BLOCK的兩頭向中間擴(kuò)展,中間未用的部分就是FREE SPACE。 有4個(gè)參數(shù)控制著B(niǎo)LOCK的分配:INITTRANS, MAXTRANS, PCTFREE, PCTUSED。 描述如下:BLOCK下包含數(shù)據(jù)允許最大的操作事務(wù)個(gè)數(shù)取決于BLOCK某種空間(TRANSACTION SLOT)的分配。允許的事務(wù)越多,需要分配越多的TRANS SLOT。INITTRANS和MAXTRANS就是規(guī)定這個(gè)TRANSACTION SLOT的。 PCTFREE和PCTUSED是規(guī)定DATA SPACE和FREE SPACE之間關(guān)系的:當(dāng)一個(gè)空的BLOCK開(kāi)始寫(xiě)入數(shù)據(jù)后,DATA SPACE部分越來(lái)越大,同時(shí),FREE SPACE越來(lái)越小。當(dāng)數(shù)據(jù)寫(xiě)入到一定程度時(shí),FREE SPACE占全部空間等于PCTFREE時(shí),這個(gè)BLOCK就不能再寫(xiě)入新的記錄了。剩下的這部分(PCTFREE*DB_BLOCK_SIZE)空間用于給現(xiàn)有記錄update使用。后續(xù)的insert會(huì)導(dǎo)致從FREE BLOCK列表中拿另外一個(gè)BLOCK完成。當(dāng)BLOCK中記錄通過(guò)delete時(shí),BLOCK的DATA SPACE逐漸減少。 如果BLOCK此時(shí)是一個(gè)FULL BLOCK,當(dāng)DATA SPACE降低置DB_BLOCK_SIZE*PCTUSED后,ORACLE就認(rèn)為這個(gè)BLOCK是個(gè)FREE的BLOCK,就會(huì)放入FREE LIST,可以繼續(xù)插入數(shù)據(jù)了。可見(jiàn),PCTFREE和PCTUSED是兩個(gè)水位線,用來(lái)限制FREE、USED兩個(gè)空間分隔線的位置的。 有兩種BLOCK的空間管理模式:AUTO和MANUL。 使用前者,ORACEL會(huì)自動(dòng)管理INITTRANS, MAXTRANS, PCTFREE, PCTUSED這幾個(gè)參數(shù)。 如下是創(chuàng)建一個(gè)AUTO管理的TABLESPACE: CREATE TABLESPACE data02 DATAFILE '/u01/oradata/data02.dbf' SIZE 5M EXTENT MANAGEMENT LOCAL UNIFORM SIZE 64K SEGMENT SPACE MANAGEMENT AUTO; ———————————————————————————————————————————————????????? 區(qū)extent EXTENTS是若干連續(xù)的BLOCKS,ORACLE每次給SEGMENT擴(kuò)空間的時(shí)候,是以EXTENTS為單位的。 在建TABLE/INDEX時(shí)幾個(gè)參數(shù)決定了EXTENTS的分配特性:INITIAL EXTENT(單位:K)、NEXT EXTENTS(單位:K)、PCT INCREASE、MIN EXTENTS(單位:個(gè))、MAX EXTENTS(單位:個(gè))。 基本過(guò)程是這樣:當(dāng)SEGMENT創(chuàng)建時(shí),分配的第一個(gè)EXTENTS大小為INITIAL EXTENT參數(shù)指定的大小。 如果SEGMENT的空間不夠,會(huì)分配第2個(gè)、第3個(gè)...EXTENTS。 第2個(gè)EXTENT的大小為NEXT EXTENTS, 第3個(gè)的大小為NEXT EXTENTS*(1+PCT INCREASE), 每次增加PCT INCREASE,以此類(lèi)推。? 每個(gè)TABLESPACE都有一個(gè)FREE EXTENTS LIST。 當(dāng)需要新的EXTENTS時(shí),ORACLE會(huì)從這個(gè)LIST中取一個(gè)FREE EXTENT分配給需要的SEGMENT。 當(dāng)SEGMENT釋放空間時(shí),空閑的EXTENTS會(huì)加入到這個(gè)LIST中以便后續(xù)使用。 段segment CREATE TABLE/INDEX 的STORAGE字句,用來(lái)指定存儲(chǔ)特性。如果沒(méi)有指定,按照TABLESPACE的STORAGE屬性來(lái),如果TABLESPACE也沒(méi)有指定STORAGE屬性,則按照ORACLE的默認(rèn)值來(lái)。 通常,一個(gè)TABLE對(duì)應(yīng)一個(gè)SEGMENT(PARTITION的除外)。 一個(gè)SEGMENT只能在一個(gè)TABLESPACE內(nèi)部。 對(duì)于PARTITIONED表每個(gè)PARTITION占一個(gè)SEGMENT,每個(gè)SEGMENT可以在不同的TABLESPACE中。

?

轉(zhuǎn)載于:https://blog.51cto.com/huangxiaohui91/397144

總結(jié)

以上是生活随笔為你收集整理的Oracle学习(1)——BLOCK的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。