近期在自建數(shù)據(jù)分析平臺(tái)的時(shí)候上煤,遇到了事實(shí)表包含兩個(gè)業(yè)務(wù)時(shí)間語(yǔ)義的問題米绕,結(jié)合數(shù)倉(cāng)事實(shí)表建設(shè)方面的方法論款侵,整理記錄一些自己的想法娇哆。
事實(shí)表的通撑壤郏可以劃分為如下三類:
- 事務(wù)事實(shí)表
- 周期快照事實(shí)表
- 累積快照事實(shí)表
事務(wù)事實(shí)表又可以分為單事務(wù)事實(shí)表和多事務(wù)事實(shí)表勃救。以訂單過程為例,一個(gè)訂單業(yè)務(wù)過程可以簡(jiǎn)化為下單和支付兩個(gè)業(yè)務(wù)事件治力,兩個(gè)事件共享一個(gè)訂單Id及相應(yīng)商品的維度信息蒙秒,但這兩個(gè)事件可以有不同的業(yè)務(wù)度量,舉例來(lái)講就是下單時(shí)有下單金額宵统,支付時(shí)有實(shí)際支付金額晕讲,優(yōu)惠金額等等。
對(duì)于數(shù)倉(cāng)建設(shè)來(lái)講马澈,在描述訂單業(yè)務(wù)過程瓢省,設(shè)計(jì)訂單事實(shí)表模型時(shí),就會(huì)面臨一個(gè)選擇:將下單和支付兩個(gè)業(yè)務(wù)事件拆開痊班,分別構(gòu)建單事務(wù)事實(shí)表還是構(gòu)建一張多事務(wù)事實(shí)表勤婚。
如果選擇構(gòu)建單事務(wù)事實(shí)表,優(yōu)點(diǎn)在于各個(gè)事實(shí)表的業(yè)務(wù)語(yǔ)義明確涤伐,表分區(qū)字段直接采用表達(dá)的業(yè)務(wù)時(shí)間即可馒胆,方便下游使用方理解,缺點(diǎn)則是會(huì)冗余訂單維度相關(guān)的數(shù)據(jù)凝果,并且對(duì)于同時(shí)查詢下單和支付度量時(shí)祝迂,會(huì)有表連接的計(jì)算開銷。
那么構(gòu)建多事務(wù)事實(shí)表呢器净?此時(shí)表分區(qū)字段就不由具體的業(yè)務(wù)語(yǔ)義液兽,需要在表中增加相應(yīng)字段用明確時(shí)間語(yǔ)義。舉例來(lái)講對(duì)于2021-01-26的分區(qū)掌动,需要有 '是否當(dāng)天下單'&'是否當(dāng)天支付'兩個(gè)字段來(lái)輔助判斷分區(qū)的時(shí)間語(yǔ)義,然后在表中包含下單和支付的度量宁玫,對(duì)于尚未發(fā)生的度量粗恢,可以置零。采用這種方案欧瘪,對(duì)于下游使用有一定的理解難度眷射,且度量中可能會(huì)有很多0值,但可以避免表連接問題佛掖。
上面是在相關(guān)數(shù)據(jù)建設(shè)書籍上看到的兩種解決方案妖碉,兩種方案的出發(fā)點(diǎn)都是在與每個(gè)分區(qū)只保存增量的數(shù)據(jù),盡量避免存儲(chǔ)上的浪費(fèi)芥被,同時(shí)分區(qū)數(shù)據(jù)量減少欧宜,也可以提升查詢計(jì)算的速度,降低計(jì)算的開銷拴魄。
除上述方法之外冗茸,如果每天增量的訂單數(shù)據(jù)并不太大席镀,還有第三種方案可以采用(也就是我們現(xiàn)在在用的方案):依然是合并成一個(gè)事實(shí)表,但是每天的分區(qū)都是全量數(shù)據(jù)夏漱,以訂單Id作為主鍵豪诲,每條記錄保留所有跟訂單相關(guān)的業(yè)務(wù)事件的維度&度量信息。也就是說(shuō)挂绰,分區(qū)字段就沒有任何業(yè)務(wù)含義屎篱,需要下游在使用時(shí)根據(jù)具體需求去采用相應(yīng)的時(shí)間語(yǔ)義字段。采用這種方案葵蒂,開發(fā)上難度較低交播,但會(huì)有較大的存儲(chǔ)浪費(fèi),并且每個(gè)分區(qū)保存全量數(shù)據(jù)刹勃,在計(jì)算時(shí)也會(huì)有較大的資源開銷堪侯。