從 TPCH 測試學習性能優(yōu)化技巧之 Q11

一浸间、???? 查詢要求

Q11語句是查詢庫存中某個國家供應的零件的價值套蒂。

Q11語句的特點是:帶有分組钞支、排序、聚集操刀、子查詢操作并存的多表連接查詢操作烁挟。子查詢位于分組操作的HAVING條件中。


二骨坑、???? Oracle執(zhí)行

Oracle編寫的查詢SQL語句如下:

select? /*+ parallel(n) */

???????? ps_partkey,

???????? sum(ps_supplycost * ps_availqty) as value

from

???????? partsupp,

???????? supplier,

???????? nation

where

???????? ps_suppkey = s_suppkey

???????? and s_nationkey = n_nationkey

???????? and n_name = 'CHINA'

group by

???????? ps_partkey

having

???????? sum(ps_supplycost * ps_availqty) > (

?????????????????? select

?????????????????? ???????? sum(ps_supplycost * ps_availqty) * 0.000001

?????????????????? from

?????????????????? ???????? partsupp,

???????? ?????????????????? supplier,

??????????????????????????? nation

?????????????????? where

?????????????????? ???????? ps_suppkey = s_suppkey

??????????????????????????? and s_nationkey = n_nationkey

?????????????????? ???????? and n_name = 'CHINA'

???????? )

order by

???????? value desc;

其中/*+ parallel(n) */ 是Oracle的并行查詢語法撼嗓,n是并行數(shù)。

腳本執(zhí)行時間欢唾,單位:秒

并行數(shù)? ? ? ? ? ? ?1? ? ? ? ? ? 2? ? ? ? ? ?4? ? ? ? ? ?8? ? ? ? ? 12

Oracle? ? ? ? ? ? 71? ? ? ? ? ?52? ? ? ? ? 43? ? ? ? ?36? ? ? ? 33


三且警、???? SPL優(yōu)化

我們把下面的子查詢看成為視圖V:

?????????????????? select

??????????????????????????? ps_partkey,

??????????????????????????? sum(ps_supplycost * ps_availqty) as value

?????????????????? from

?????????????????? ???????? partsupp,

???????? ?????????????????? supplier,

??????????????????????????? nation

?????????????????? where

?????????????????? ???????? ps_suppkey = s_suppkey

??????????????????????????? and s_nationkey = n_nationkey

?????????????????? ???????? and n_name = 'CHINA'

則原主體查詢等價于

?????????????????? select

???????? ?????????????????? ps_partkey,

??????????????????????????? value

?????????????????? from V

?????????????????? where value>0.000001*(select sum(value) from V)

???????? 這個V已經(jīng)是經(jīng)過分組后的結(jié)果集,數(shù)量較小礁遣,遍歷V比直接針對partsupp遍歷的計算量要小很多斑芜。

???????? 而我們還知道,partsupp表是按主鍵ps_partkey,ps_suppkey有序的祟霍,也就是對ps_partkey有序押搪,這時候針對該字段的分組可以使用有序分組方案,以提高計算V的性能浅碾。


SPL腳本如下:

A

1=1

2=now()

3>name="CHINA"

4>percent=0.000001

5=file(path+"nation.ctx").create().cursor(N_NATIONKEY,N_NAME;N_NAME ? == name).fetch().keys@i(N_NATIONKEY)

6=file(path+"supplier.ctx").create().cursor@m(S_SUPPKEY;A5.find(S_NATIONKEY);A1)

7=A6.fetch().keys@i(S_SUPPKEY)

8=file(path+"partsupp.ctx").create().cursor@m(PS_PARTKEY,PS_AVAILQTY,PS_SUPPLYCOST;A7.find(PS_SUPPKEY);A1)

9=A8.fetch()

10=A9.groups@o(PS_PARTKEY;sum(PS_SUPPLYCOST ? * PS_AVAILQTY):value)

11=A10.sum(value) ? * percent

12=A10.select(value ? > A11)

13=A12.sort@o(value:-1)

14=now()

15=interval@s(A2,A14)

A10用groups@o執(zhí)行有序分組大州,相當于計算出視圖V,然后A11,A12對A10進行兩次遍歷計算出結(jié)果垂谢。


腳本執(zhí)行時間厦画,單位:秒

并行數(shù)? ? ? ? ?1? ? ? ? ? ? 2? ? ? ? ? 4? ? ? ? ? ? 8? ? ? ? ? ? ?12

Oracle? ? ? ? 71? ? ? ? ? ?52? ? ? ? ? 43? ? ? ? ?36? ? ? ? ? ?33

SPL組表? ? ?24? ? ? ? ? ?15? ? ? ? ? ?9? ? ? ? ? ? 6? ? ? ? ? ? 5

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市滥朱,隨后出現(xiàn)的幾起案子根暑,更是在濱河造成了極大的恐慌,老刑警劉巖徙邻,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件排嫌,死亡現(xiàn)場離奇詭異,居然都是意外死亡缰犁,警方通過查閱死者的電腦和手機淳地,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進店門怖糊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人颇象,你說我怎么就攤上這事伍伤。” “怎么了遣钳?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵扰魂,是天一觀的道長。 經(jīng)常有香客問我蕴茴,道長劝评,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任倦淀,我火速辦了婚禮蒋畜,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘晃听。我一直安慰自己百侧,他們只是感情好,可當我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布能扒。 她就那樣靜靜地躺著佣渴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪初斑。 梳的紋絲不亂的頭發(fā)上辛润,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天,我揣著相機與錄音见秤,去河邊找鬼砂竖。 笑死,一個胖子當著我的面吹牛鹃答,可吹牛的內(nèi)容都是我干的乎澄。 我是一名探鬼主播,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼测摔,長吁一口氣:“原來是場噩夢啊……” “哼置济!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起锋八,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤浙于,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后挟纱,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體羞酗,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年紊服,在試婚紗的時候發(fā)現(xiàn)自己被綠了檀轨。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片胸竞。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖裤园,靈堂內(nèi)的尸體忽然破棺而出撤师,到底是詐尸還是另有隱情剂府,我是刑警寧澤拧揽,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站腺占,受9級特大地震影響淤袜,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜衰伯,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一铡羡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧意鲸,春花似錦烦周、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至槐雾,卻和暖如春夭委,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背募强。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工株灸, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人擎值。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓慌烧,卻偏偏與公主長得像,于是被迫代替她去往敵國和親鸠儿。 傳聞我的和親對象是個殘疾皇子屹蚊,可洞房花燭夜當晚...
    茶點故事閱讀 43,627評論 2 350

推薦閱讀更多精彩內(nèi)容