資料分割儲存模式及處理
資料分割的儲存模式會影響查詢及處理效能、儲存需求,以及此資料分割的儲存位置及其父量值群組和 Cube。 儲存模式的選擇也會影響處理選擇。
資料分割可以使用三種基本儲存模式之一:
多維度 OLAP (MOLAP)
關聯式 OLAP (ROLAP)
混合式 OLAP (HOLAP)
Microsoft SQL Server Analysis Services支援這三種基本儲存模式。 另外也支援主動式快取,可以讓您結合 ROLAP 和 MOLAP 儲存的特性,提供資料的立即性和查詢效能。 如需詳細資訊,請參閱 主動式快取 (分割區) 。
MOLAP
MOLAP 儲存模式會在處理分割區時,將分割區的匯總及其來源資料的複本儲存在 Analysis Services 的多維度結構中。 這個 MOLAP 結構會高度最佳化,以發揮最大的查詢效能。 儲存位置可以位於定義分割區的電腦上,或位於執行 Analysis Services 的另一部電腦上。 由於來源資料的副本會位於多維度結構中,所以可以在不存取資料分割之來源資料的情況下解析查詢; 查詢回應時間會因為使用彙總而大幅縮減。 此資料分割之 MOLAP 結構中的資料只會維持在與此資料分割的最新處理一樣的最新狀態。
隨著來源資料的變更,必須要定期處理 MOLAP 儲存中的物件,以便納入這些變更,並將這些變更提供給使用者。 處理時會更新 MOLAP 結構中的資料 (完整更新或累加更新)。 某一個處理和下一個處理之間的時間,會產生一段延遲期間,在這段期間內,OLAP 物件中的資料可能會與來源資料不相符。 您可以用累加或完整方式來更新 MOLAP 儲存中的物件,而不用讓資料分割或 Cube 離線工作; 但是在一些情況下,您可能需要讓 Cube 離線工作,才能夠處理對 OLAP 物件的某些結構性變更。 您可以在臨時伺服器上更新和處理 Cube,並使用資料庫同步處理,將處理好的物件複製到實際伺服器,以減少更新 MOLAP 儲存所需的停機時間。 您也可以使用主動式快取,來減少延遲並提高可用性,同時還保持 MOLAP 儲存的大部分效能優點。 如需詳細資訊,請參閱 主動式快取 (分割區) 、 同步處理 Analysis Services 資料庫和 多維度模型物件處理。
ROLAP
ROLAP 儲存模式會將資料分割的彙總儲存在關聯式資料庫內的索引檢視中 (這個關聯式資料庫是指定於資料分割的資料來源中)。 不同于 MOLAP 儲存模式,ROLAP 不會造成來源資料的複本儲存在 Analysis Services 資料檔案夾中。 而是在無法從查詢快取中衍生結果時,存取資料來源中的索引檢視來回答查詢。 使用 ROLAP 儲存模式的查詢回應通常會比使用 MOLAP 或 HOLAP 儲存模式的查詢回應慢。 使用 ROLAP 的處理時間通常也比較慢。 但是,ROLAP 會讓使用者即時檢視資料,而且當您在使用不常被查詢的大型資料集 (例如,純綷的記錄資料) 時,可以節省儲存空間。
注意
使用 ROLAP 時,如果聯結與 GROUP BY 子句結合,Analysis Services 可能會傳回與未知成員相關的不正確資訊。 Analysis Services 會消除關聯式完整性錯誤,而不是傳回未知的成員值。
如果分割區使用 ROLAP 儲存模式,且其來源資料儲存在 SQL Server Database Engine 中,Analysis Services 會嘗試建立索引檢視,以包含分割區的匯總。 如果 Analysis Services 無法建立索引檢視表,則不會建立匯總資料表。 雖然 Analysis Services 會處理在 SQL Server Database Engine 上建立索引檢視的會話需求,但 ROLAP 分割區和其架構中的資料表必須符合下列條件,Analysis Services 才能建立匯總的索引檢視表:
資料分割不能包含使用
Min
或Max
彙總函式的量值。ROLAP 資料分割之結構描述中的每份資料表都只能使用一次。 例如,結構描述不能包含 [dbo].[address] AS "Customer Address" 和 [dbo].[address] AS "SalesRep Address"。
每個資料表都必須是一個資料表,而不是一個檢視。
資料分割之結構描述中的所有資料表名稱都必須具有擁有者的完整名稱 (例如,[dbo].[customer])。
資料分割之結構描述中的所有資料表都必須具有相同的擁有者;例如,您不可擁有參考 [tk].[customer]、[john].[store] 和 [dave].[sales_fact_2004] 資料表的 FROM 子句。
資料分割之量值的來源資料行不可為 Null。
用於檢視中的所有資料表,必須在下列選項設定成 ON 的情況下建立:
ANSI_NULLS
QUOTED_IDENTIFIER
SQL Server Database Engine 中索引鍵的大小總計不能超過 900 個位元組。 SQL Server Database Engine 會在處理 CREATE INDEX 語句時,根據固定長度索引鍵資料行判斷這個條件。 不過,如果索引鍵中有可變長度的資料行,SQL Server Database Engine 也會針對基表的每個更新判斷這個條件。 因為不同彙總有不同的檢視定義,所以會依彙總設計而定,使用索引檢視的 ROLAP 處理可能成功也可能失敗。
建立索引檢視的工作階段必須將下列選項設為 ON:ARITHABORT、CONCAT_NULL_YEILDS_NULL、QUOTED_IDENTIFIER、ANSI_NULLS、ANSI_PADDING 和 ANSI_WARNING。 此設定可以在SQL Server Management Studio中建立。
建立索引檢視的工作階段必須將下列選項設為 OFF:NUMERIC_ROUNDABORT。 此設定可以在SQL Server Management Studio中建立。
HOLAP
HOLAP 儲存模式會結合 MOLAP 和 ROLAP 的屬性。 如同 MOLAP,HOLAP 會導致分割區的匯總儲存在SQL Server Analysis Services實例的多維度結構中。 HOLAP 不會儲存來源資料的副本。 針對只存取資料分割彙總之摘要資料的查詢,HOLAP 相當於 MOLAP。 例如,如果您想要向下切入至沒有匯總資料的不可部分完成 Cube 資料格,則存取來源資料的查詢必須從關係資料庫擷取資料,而且如果來源資料儲存在 MOLAP 結構中,則不會像這樣快。 在 HOLAP 儲存模式下,使用者經常會遇到查詢時間有大幅差異的情況,而這是根據可以從快取或彙總來解析查詢,還是從來源資料本身解析查詢而定。
因為儲存為 HOLAP 的資料分割不包含來源資料,所以會比同等的 MOLAP 資料分割還小,而且針對涉及摘要資料之查詢的回應速度也會比 ROLAP 資料分割還快。 HOLAP 儲存模式一般是適用於 Cube 中的資料分割,而這類資料分割需要根據大量來源資料以快速回應摘要查詢。 但是,如果使用者產生必須接觸分葉層級資料的查詢 (例如計算中間值),MOLAP 通常是較好的選擇。
另請參閱
主動式快取 (資料分割)
同步處理 Analysis Services 資料庫
資料分割 (Analysis Services - 多維度資料)