成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Oracle遷移到Polardb-O性能優(yōu)化案例

IT那活兒 / 2230人閱讀
Oracle遷移到Polardb-O性能優(yōu)化案例

1.在polardb-o執(zhí)行結(jié)果返回14秒


2.在oracle執(zhí)行結(jié)果返回值0.2秒


3.查看polardb-o的執(zhí)行計(jì)劃


4.為啥執(zhí)行計(jì)劃不一樣呢,統(tǒng)計(jì)信息的問(wèn)題嗎?


查詢得出,統(tǒng)計(jì)信息page數(shù)量和實(shí)際差別20%的表沒(méi)有,統(tǒng)計(jì)信息也沒(méi)有問(wèn)題。


5.那case_time這個(gè)條件有啥特殊呢?

SELECTordersum     as ordersum,

onestatus   as onestatus,

twostatus   as twostatus,

threestatus as threestatus,

fourstatus  as fourstatus,

archive     as archive,

elevenstatusas elevenstatus

FROM(SELECT ***

FROMxx a

***

ANDa.case_time >= trunc(sysdate - 30, dd))


嘗試將sysdate修改為now,執(zhí)行時(shí)間1.72秒,效率提升很多.


這個(gè)sysdate和now有啥不一樣呢?

兩者的provolatile分別為s和v,原因是sysdate這個(gè)函數(shù)被標(biāo)記為了volatile,那么它的值只有在讀到一條記錄的時(shí)候才能確定,這樣就不能走索引了。


6.pg的函數(shù)有易變性,而oracle數(shù)據(jù)庫(kù)沒(méi)有這個(gè)概念。


簡(jiǎn)單描述如下:


IMMUTABLE(非常穩(wěn)定)

表示該函數(shù)不能修改數(shù)據(jù)庫(kù)并且對(duì)于給定的參數(shù)值總是會(huì)返回相同的值。也就是說(shuō),它不會(huì)做數(shù)據(jù)庫(kù)查找或者使用沒(méi)有在其參數(shù)列表中直接出現(xiàn)的信息。如果給定合格選項(xiàng),任何用全常量參數(shù)對(duì)該函數(shù)的額調(diào)用可以立刻用該函數(shù)值替換。


STABLE(穩(wěn)定)

表示該函數(shù)不能修改數(shù)據(jù)庫(kù),并且對(duì)于相同的參數(shù)值,它在一次表掃描中將返回相同的結(jié)果。在大多數(shù)情況下是的。在單個(gè)表掃描中,對(duì)相同的參數(shù)值返回相同的結(jié)果,但結(jié)果將通過(guò)SQL語(yǔ)句進(jìn)行更改。結(jié)果取決于數(shù)據(jù)庫(kù)查找或參數(shù)值。current_timestamp系列函數(shù)是STABLE;值在執(zhí)行中不會(huì)改變。


VOLATILE(不穩(wěn)定)

默認(rèn)為VOLATILE。表示該函數(shù)的值在一次表掃描中都有可能改變,因此不能做優(yōu)化。在這種意義上,相對(duì)較少的數(shù)據(jù)庫(kù)函數(shù)是不穩(wěn)定的。例如:random(), currval(), timeofday()。任何具有副作用的函數(shù)的都不穩(wěn)定的,即使其結(jié)果是可預(yù)測(cè)的。例如:setval().


理解測(cè)試:

Oracle的sysdate的值為語(yǔ)句開始的值,并且在整個(gè)sql的生命周期中是保持不變的。


Polardb-o的sysdate的值,在每次讀一行的時(shí)候重新計(jì)算了,這樣是不能走索引的。



7.修改polardb-o的sysdate函數(shù)provolatile值。

alterfunction sysdate() strict stable;

或updatepg_proc set provolatile = s where proname = sysdate;

再次執(zhí)行查詢語(yǔ)句,返回時(shí)間2.4秒,耗時(shí)基本和oracle持平,通知應(yīng)用再次測(cè)試,反饋沒(méi)有問(wèn)題。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/130110.html

相關(guān)文章

  • 使用BenchmarkSQL對(duì)Polardb數(shù)據(jù)庫(kù)進(jìn)行TPCC測(cè)試

    使用BenchmarkSQL對(duì)Polardb數(shù)據(jù)庫(kù)進(jìn)行TPCC測(cè)試 img{ display:block; margin:0 auto !important; width:100%; } body{ width:...

    IT那活兒 評(píng)論0 收藏547
  • 新書推薦 |《PostgreSQL實(shí)戰(zhàn)》出版(提供樣章下載)

    摘要:作者譚峰張文升出版日期年月頁(yè)數(shù)頁(yè)定價(jià)元本書特色中國(guó)開源軟件推進(jìn)聯(lián)盟分會(huì)特聘專家撰寫,國(guó)內(nèi)多位開源數(shù)據(jù)庫(kù)專家鼎力推薦。張文升中國(guó)開源軟件推進(jìn)聯(lián)盟分會(huì)核心成員之一。 很高興《PostgreSQL實(shí)戰(zhàn)》一書終于出版,本書大體上系統(tǒng)總結(jié)了筆者 PostgreSQL DBA 職業(yè)生涯的經(jīng)驗(yàn)總結(jié),本書的另一位作者張文升擁有豐富的PostgreSQL運(yùn)維經(jīng)驗(yàn),目前就職于探探科技任首席PostgreS...

    Martin91 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<