成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

關于數據增量抽取模擬實現原理

數據庫
ETL是數據倉庫的一個重要處理環節,Extract即是從業務數據庫中抽取數據,Transform即是根據業務邏輯規則對數據進行加工的過程,Load即是把數據加載到數據倉庫的過程。

通常為了盡可能的減少對業務系統的壓力和性能影響,或者因為網絡傳輸異構數據庫等原因,一般都是根據特定的增量抽取原則,將數據從業務數據庫導出到flat文本文件或者XML文件中,也叫數據緩存區或者數據登臺區(這名字起得特別別扭)。本文討論的是從業務數據庫直接抽取到數據倉庫。數據倉庫是一種體系架構,而不是一種純粹的技術。實際上,大多數數據庫都提供了類似的不同數據庫直接連接的接口,例如SQL Server的鏈接數據庫,Oracle的透明網關等等。

關于數據的增量抽取也是一個重要的討論話題,其原因主要是在超大數據量情況下任何關系數據庫都無法滿足數據處理的要求。在《數據倉庫》(Inmon)一書中,主要描述了以下3種方法:

1.數據增量抽取,主要是基于時間戳的;

2.掃描增量文件,實際上就是關系數據庫的歸檔日志;

3.前后映像對比。

當然每種方法都有其優勢和劣勢,本文旨在討論基于時間戳的數據增量抽取的實現,無意探討和比較這三種方法的優劣。

當然在進行基于時間戳的數據增量處理之前,首先要滿足以下假設:

1.假設在業務數據庫中存在著一個特定的時間屬性,作為增量抽取的唯一標識;

2.假設在這個字段上存在著索引字段。這樣我們的數據增量抽取模擬腳本就不會遭遇到性能瓶頸。當然我們還會通過將大事務盡可能變成小事務的原則進行優化;

3.假設業務數據庫和數據倉庫能夠以某種方式直接連接;

4.抽取過程中,盡量避免數據轉換、清洗的動作,以減少對業務數據庫的性能影響;

在滿足了以上條件之后,我們才能進一步考慮數據增量抽取腳本的實現。

 1.建立鏈接數據庫;

2.首先需要定義一張數據字典表,定義需要進行處理的任務,其中主要包括業務數據庫和目標數據庫的表名、字段列表、以及where條件等;

3.有了這張字典表就可以開始進行工作了,為了方便表達,暫時處理成偽代碼形式,同時只以一個表的處理為例。

◆獲取數據倉庫目標表目前的***時間(讀取字典表或者當前表均可)

◆獲取業務數據庫業務表目前的***時間(需要到業務系統中去讀取)

◆如果業務數據庫業務表數據為空,退出執行

◆如果數據倉庫為空,業務數據庫不為空,則再次讀取業務數據庫最小時時間

◆如果均不為空,則設置開始抽取最小時間和***時間

◆***時間設置為整點

◆根據控制事務處理大小的粒度,進行循環抽取

◆拼寫SQL語句,寫成類似以下的形式

INSERT INTO TargetTable (TargetFieldList) 
  SELECT SourceFieldList FROM SourceTable 
  WHERE WhereFieldName> BeginDate 
  AND WhereFieldName< BeginDate+粒度

◆處理狀態寫入該字典表

4.有一點要主要的是,在SQL Server中有兩種使用鏈接數據庫的方法:

OPENQUERY ( linked_server , 'query' )

linked_server_name.catalog.schema.object_name的四部分名稱

這兩種方法各有利弊,第二種容易閱讀一些;***種方法據說把語句提交到源數據庫執行的,效率可能會高些(實際的資料并未找到)。

其次這兩種方法在使用起來語法有點差別,***種方法采用的是宿主數據庫的語法形式,第二種方法采用的是SQLServer本身的語法形式。因此在寫腳本的時候也會有所不同。主要差別是在字段列表和條件處,暫時采用***種方式。

【編輯推薦】

  1. Oracle 11g R1中AWR基線增強
  2. Oracle 11g R1中大小寫敏感的密碼
  3. 解析Oracle 11g閃回數據歸檔新功能
責任編輯:楊鵬飛 來源: 百度blog
相關推薦

2024-10-07 10:02:28

2021-05-14 16:34:12

Semaphore原理

2018-08-14 14:20:40

MongoDBStream數據遷移

2011-08-25 10:07:24

Lua 5.0函數編譯器

2010-03-05 13:29:00

Python增量備份

2011-06-13 10:21:25

QT 信號 槽機制

2011-08-15 09:48:30

MySQL數據庫完整備份增量備份

2022-11-30 18:38:50

數據血緣DataLeap

2018-11-08 10:13:28

Rsync服務器備份

2017-02-08 11:00:50

數據庫索引類型

2021-02-09 09:51:58

異步傳遞數據

2017-09-06 10:55:19

Java

2018-07-13 08:56:16

編程語言Python

2024-11-04 16:29:19

2021-12-27 09:59:57

SpringCanal 中間件

2018-04-12 07:10:23

2017-07-11 13:58:10

WebSocket

2010-09-26 10:09:25

dhcp relay工

2016-12-21 14:06:55

日志實現數據實時抽取
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人欧美一区二区三区在线观看 | 日本电影韩国电影免费观看 | 亚洲精品一二区 | 日韩在线视频一区 | 中文字幕在线第二页 | 黑人精品欧美一区二区蜜桃 | 国精品一区 | 日韩欧美在线视频一区 | 日韩欧美一区二区三区免费看 | 亚洲不卡在线观看 | 综合色久 | a级片在线观看 | 在线观看免费av网 | 成人av电影免费在线观看 | 精精国产xxxx视频在线播放7 | 日韩中文视频 | 99av成人精品国语自产拍 | 久久福利网站 | 99色综合| 欧美成人免费 | 国产一区二区视频在线观看 | 欧美精品区 | 亚洲一区成人 | 亚洲成人动漫在线观看 | 91精品国产综合久久香蕉麻豆 | 午夜极品| 视频一区二区在线观看 | av大全在线观看 | 国产伦精品一区二区三毛 | 人妖videosex高潮另类 | 国产精品视频中文字幕 | 高清国产午夜精品久久久久久 | 九色 在线 | 精品综合| jizz亚洲人| 免费高潮视频95在线观看网站 | 欧美日韩综合一区 | 黄色免费在线观看 | 日韩一区二区三区在线 | 精品乱码一区二区三四区 | 911网站大全在线观看 |