新聞中心
Oracle有很多值得學(xué)習(xí)的地方,這里我們主要介紹Oracle編碼SQL,包括介紹SQL語(yǔ)句等方面。為了不重復(fù)解析相同的SQL語(yǔ)句(因?yàn)榻馕霾僮鞅容^費(fèi)資源,會(huì)導(dǎo)致性能下降),在***次解析之后,Oracle將SQL語(yǔ)句及解析后得到的執(zhí)行計(jì)劃存放在內(nèi)存中。這塊位于系統(tǒng)全局區(qū)域SGA(system global area)的共享池(shared buffer pool)中的內(nèi)存可以被所有的數(shù)據(jù)庫(kù)用戶共享。

#t#因此,當(dāng)你執(zhí)行一個(gè)SQL語(yǔ)句(有時(shí)被稱為一個(gè)游標(biāo))時(shí),如果該語(yǔ)句和之前的執(zhí)行過(guò)的某一語(yǔ)句完全相同,并且之前執(zhí)行的該語(yǔ)句與其執(zhí)行計(jì)劃仍然在內(nèi)存中存在,則Oracle就不需要再進(jìn)行分析,直接得到該語(yǔ)句的執(zhí)行路徑。
Oracle的這個(gè)功能大大地提高了 SQL的執(zhí)行性能并大大節(jié)省了內(nèi)存的使用。使用這個(gè)功能的關(guān)鍵是將執(zhí)行過(guò)的語(yǔ)句盡可能放到內(nèi)存中,所以這要求有大的共享池(通過(guò)設(shè)置shared buffer pool參數(shù)值)和盡可能的使用綁定變量的方法執(zhí)行SQL語(yǔ)句。
當(dāng)你向Oracle 提交一個(gè)SQL語(yǔ)句,Oracle會(huì)首先在共享內(nèi)存中查找是否有相同的語(yǔ)句。這里需要注明的是,Oracle對(duì)兩者采取的是一種嚴(yán)格匹配,要達(dá)成共享,SQL語(yǔ)句必須完全相同(包括空格,換行等)。
下面是判斷SQL語(yǔ)句是否與共享內(nèi)存中某一SQL相同的步驟:
1). 對(duì)所發(fā)出語(yǔ)句的文本串進(jìn)行hashed。如果hash值與已在共享池中SQL語(yǔ)句的hash值相同。
2) 將所發(fā)出語(yǔ)句的文本串
- str_sql string;
- int_empno int;
- int_empno = 2000;
- str_sql = ‘SELECT * FROM emp WHERE empno = ‘ + int_empno;
- …………
- int_empno = 1000;
- str_sql = ‘SELECT * FROM emp WHERE empno = ‘ + int_empno;
上面的代碼實(shí)際上使用了Oracle編碼SQL,使我們不能使用共享SQL的功能,結(jié)果是數(shù)據(jù)庫(kù)效率不高。但是從上面的2個(gè)語(yǔ)句來(lái)看,產(chǎn)生的Oracle編碼SQL 只是列值不同,其它部分都是相同的,如果僅僅因?yàn)榱兄挡煌鴮?dǎo)致這2個(gè)語(yǔ)句不能共享是很可惜的,為了解決這個(gè)問(wèn)題,引入了CURSOR_SHARING參數(shù),使這類問(wèn)題也可以使用共享SQL,從而使這樣的開(kāi)發(fā)也可以利用共享SQL功能。
聽(tīng)起來(lái)不錯(cuò),Oracle真為用戶著想,使用戶在不改變代碼的情況下還可以利用共享SQL的功能。真的如此嗎?天上不會(huì)無(wú)緣無(wú)故的掉一個(gè)餡餅的,Oracle對(duì)該參數(shù)的使用做了說(shuō)明,建議在經(jīng)過(guò)實(shí)際測(cè)試后再改該參數(shù)的值(缺省情況下,該參數(shù)的值為EXACT,語(yǔ)句完全一致才使用共享SQL)。
因?yàn)橛锌赡茉撟冊(cè)撝岛螅愕腛racle編碼SQL是可以使用共享SQL 了,但數(shù)據(jù)庫(kù)的性能反而會(huì)下降。 我在實(shí)際應(yīng)用中已經(jīng)遇到這種情況。所以建議編寫(xiě)需要穩(wěn)定運(yùn)行程序的開(kāi)發(fā)人員***還是一開(kāi)始就使用綁定變量的SQL。
當(dāng)前題目:簡(jiǎn)單描述Oracle編碼SQL
鏈接地址:http://www.5511xx.com/article/djejgop.html


咨詢
建站咨詢
