SQLSELECT (1 - ROUND(BYTES / (TSP_IN_M * 1024 * 1024), 2)) * 100 || '%'
公司專注于為企業(yè)提供成都網(wǎng)站制作、成都網(wǎng)站設(shè)計、微信公眾號開發(fā)、商城系統(tǒng)網(wǎng)站開發(fā),微信小程序定制開發(fā),軟件按需定制制作等一站式互聯(lián)網(wǎng)企業(yè)服務(wù)。憑借多年豐富的經(jīng)驗,我們會仔細(xì)了解各客戶的需求而做出多方面的分析、設(shè)計、整合,為客戶設(shè)計出具風(fēng)格及創(chuàng)意性的商業(yè)解決方案,創(chuàng)新互聯(lián)建站更提供一系列網(wǎng)站制作和網(wǎng)站推廣的服務(wù)。
FROM V$SGASTAT
WHERE NAME = 'free memory' AND POOL = 'shared pool';
其中: TSP_IN_M是你的總的共享池的SIZE(M)
oracle會把自動統(tǒng)計常用的數(shù)據(jù),經(jīng)過分析,把常用的數(shù)據(jù)預(yù)先放在緩存里,如果未來訪問的數(shù)據(jù)正好在緩存里,這樣就叫做命中,出現(xiàn)命中的幾率叫命中率或者集中率,這個數(shù)值越高,說明oracle系統(tǒng)運行的越有效率
影響命中率的因素有四種:字典表活動、臨時段活動、回滾段活動、表掃描, 應(yīng)用DBA可以對這四種因素進(jìn)行分析,找出數(shù)據(jù)庫命中率低的癥結(jié)所在。 1)字典表活動 當(dāng)一個SQL語句第一次到達(dá)Oracle內(nèi)核時數(shù)據(jù)庫對SQL語句進(jìn)行分析,包含在查詢中的數(shù)據(jù)字典對象被分解,產(chǎn)生SQL執(zhí)行路徑。如果SQL語句指向一個不在SGA中的對象?表或視圖,Oracle執(zhí)行SQL語句到數(shù)據(jù)典中查詢有關(guān)對象的信息。數(shù)據(jù)塊從數(shù)據(jù)字典表被讀取到SGA的數(shù)據(jù)緩存中。由于每個數(shù)據(jù)字典都很小,因此,我們可緩存這些表以提高對這些表的命中率。但是由于數(shù)據(jù)字典表的數(shù)據(jù)塊在SGA中占據(jù)空間,當(dāng)增加全部的命中率時,它們會降低表數(shù)據(jù)塊的可用空間, 所以若查詢所需的時間字典信息已經(jīng)在SGA緩存中,那么就沒有必要遞歸調(diào)用。 2)臨時段的活動 當(dāng)用戶執(zhí)行一個需要排序的查詢時,Oracle設(shè)法對內(nèi)存中排序區(qū)內(nèi)的所有行進(jìn)行排序,排序區(qū)的大小由數(shù)據(jù)庫的init.ora文件的數(shù)確定。如果排序區(qū)域不夠大,數(shù)據(jù)庫就會在排序操作期間開辟臨時段。臨時段會人為地降低OLTP(online transaction processing)應(yīng)用命中率,也會降低查詢進(jìn)行排序的性能。如果能在內(nèi)存中完成全部排序操作,就可以消除向臨時段寫數(shù)據(jù)的開銷。所以應(yīng)將SORT_AREA_SIZE設(shè)置得足夠大,以避免對臨時段的需要。這個參數(shù)的具體調(diào)整方法是:查詢相關(guān)數(shù)據(jù),以確定這個參數(shù)的調(diào)整。 select * from v$sysstat where name='sorts(disk)'or name='sorts(memory); 大部分排序是在內(nèi)存中進(jìn)行的,但還有小部分發(fā)生在臨時段, 需要調(diào)整 值,查看init.ora文件的 SORT_AREA_SIZE值,參數(shù)為:SORT_AREA_SIZE=65536;將其調(diào)整到SORT_AREA_SIZE=131072、這個值調(diào)整后,重啟ORACLE數(shù)據(jù)庫即可生效。 3)回滾段的活動 回滾段活動分為回滾活動和回滾段頭活動。對回滾段頭塊的訪問會降低應(yīng)用的命中率, 對OLTP系統(tǒng)命中率的影響最大。為確認(rèn)是否因為回滾段影響了命中率,可以查看監(jiān)控輸出報表中的“數(shù)據(jù)塊相容性讀一重寫記錄應(yīng)用” 的統(tǒng)計值,這些統(tǒng)計值是用來確定用戶從回滾段中訪問數(shù)據(jù)的發(fā)生次數(shù)。 4)表掃描 通過大掃描讀得的塊在數(shù)據(jù)塊緩存中不會保持很長時間, 因此表掃描會降低命中率。為了避免不必要的全表掃描,首先是根據(jù)需要建立索引,合理的索引設(shè)計要建立人對各種查詢的分析和預(yù)測上,筆者會在SQL優(yōu)化中詳細(xì)談及;其次是將經(jīng)常用到的表放在內(nèi)存中,以降低磁盤讀寫次數(shù)。
select sum(case suc when '2222222:0' then 1 else 0 end)/(sum(case suc when '2222222:0' then 1 else 0 end)+sum(case suc when '2222222:1' then 1 else 0 end)) from a;
直接判斷unpass =0 并且pass 》0的就是就是100%了。
比如:
select decode(unpass,0,decode(pass,0,'','100%'),pass*100/(pass + unpass))||'%' from tablename