sql server作業實現數據同步


作業介紹

     SQL SERVER的作業是一系列由SQL SERVER代理按順序執行的指定操作。作業可以執行一系列活動,包括運行Transact-SQL腳本、命令行應用程序、Microsoft ActiveX腳本、Integration Services 包、Analysis Services 命令和查詢或復制任務。作業可以運行重復任務或那些可計划的任務,它們可以通過生成警報來自動通知用戶作業狀態,從而極大地簡化了 SQL Server 管理[參見MSDN]。

    創建作業、刪除作業、查看作業歷史記錄....等所有操作都可以通過SSMS管理工具GUI界面操作,有時候也確實挺方便的。但是當一個實例有多個作業或多個數據庫實例時,通過圖形化的界面去管理、維護作業也是個頭痛的問題,對於SQL腳本與GUI界面管理維護作業熟優熟劣這個問題,只能說要看場合。下面主要介紹通過SQL腳本來管理、維護作業。

作業優劣

     作業適合一些簡單的操作,主要是定時執行一些計划,利用JOB定時執行,先清空本地數據,然后從遠程LinkServer遠程數據庫提取數據插入當前數據庫,方式簡單,操作容易,但是效率低,不需要檢查事物日志去比較差異。

     但是頻繁的清空,插入,如果數據量比較大時候。效率會很低,而且進行一些復雜的操作是有點困難。主要看你的需求是咋樣。

實際例子

  需求:將一台服務器上的sql server2005某一些表的數據同步到另一台服務器裝有sql server 2008的數據庫中。在同步中,有一些數據4小時更新一次。另外一些2小時更新一次。

   設計:由於操作簡單我們首選采用server JOB來完成。在目標數據庫中來完成作業創建。因為sql server2005版本有點低。定時將SourceDate中數據更新到目標數據庫中,

         首先刪除目標數據庫中數據,然后進行插入操作。有些需求不需要刪除所有數據,但是你進行一些判斷是否存在要更新和插入。在JOB不好操作,我暫時沒有發現好的方法,只能將表清空,然后在插入,但是這樣數據量大的時候就會慢下來。

         這里有兩種辦法實現設計,第一種就是源數據源中創建作業,另外一種是就是目標數據源中創建作業因為sql server2005版本有點低。定時將SourceDate中數據更新到目標數據庫中,

         這里有兩種辦法實現遠程數據庫連接,第一種就是在創建作業鏈接遠程數據庫中采用腳本連接,另外一種是利用GUI界面中在鏈接服務器中創建連接即可,我個人認為有界面版的好一些。

   實現:①:在源數據庫服務器上建立鏈接服務器。【服務器對象】-【鏈接服務器】-右鍵【新建鏈接服務器(N)...】-【常規】(如下圖)

 

 

 

    注 意:鏈接服務器IP:192.168.1.65是目標數據庫,建立這個鏈接服務器准備直接訪問192.168.1.65的服務器上的數據庫表。由於這里是 SQL SERVER 所以服務器類型選擇SQL Server。

 

   ②:選擇【安全性】設置登錄用戶和密碼,添加一個本地服務器登錄到遠程服務器的登錄映射。然后【確定】(如下圖)

 

 

 

 

 

 

    ③:這時可以看到了一個192.168.1.56的鏈接服務器。右鍵【測試連接(T)】(如下圖)

 

 

 

 

   ④:如果出現如下對話框則說明配置正確(如下圖)

 

 

 

   

    在源數據庫服務器上建立一個job主動的把數據push到目標數據庫里去。

    ⑤:新建立作業:【SQL Server 代理】-【作業】-右鍵【新建作業(N)...】

 
 

   ⑥:在【常規】中為作業起個名稱(如下圖)

 
 

   ⑦:點擊【步驟】,然后點擊【新建(N)...】創建作業步驟(如下圖)

 
 

   ⑧:編輯步驟(如下圖),然后【確定】

   從源數據庫push數據到目標數據庫的sql語句:

   truncate table [192.168.1.56].TargetData.[dbo].[TargetTable]

   go

   insert into [192.168.1.56 ].TargetData.[dbo].[TargetTable ] select * from SourceData.[dbo].[SourceTable]

   go

 
 

   ⑨:新建作業計划(如下圖),然后【確定】

 
 
   

    ⑩:最終【確定】就可以了(如下圖)

 
 

   11:執行SQL JOB,右鍵點擊剛新建的作業【PushDataToTarget】-【作業開始步驟(T)...】(如下圖)

 
 

   12:結果出現下面的問題(如下圖)

 
 

    13:然后去查看日志右鍵點擊【PushDataToTarget】-【查看歷史記錄(V)】(如下圖)

 
 
 
 
=============================================================
 
 

     方法二:在目標數據庫服務器上建立一個鏈接服務器,讓目標數據庫主動的把數據pull到源數據庫中。

    1:創建鏈接服務器 參照上方的方法,並測試鏈接成功。然后在目標數據中新建作業,如下圖

 
 

  2、新建步驟(如下圖)

  從源數據庫pull數據的sql語句:

  truncate table TargetData.[dbo].[TargetTable]

  go

  insert into TargetData.[dbo].[TargetTable ] select * from [192.168.2.200].SourceData.[dbo].[SourceTable]

  go

 

 
 

   3、新建計划(如下圖)

 
 

  4、最終【確定】

 
 

   5、右鍵點擊【PullDataFromSource】-【作業開始步驟(T)...】

 
 

   6、執行結果如下

 

 

   7、再查看日志如下

 
 

  8:表明執行結果是成功的。從上面的操作中可以總結出:

  鏈接服務器的兩個特點:

    1.通過鏈接服務器不能刪除(including truncate)鏈接源服務器的任何對像.

    2:能過鏈接服務器可以對鏈接源服務器的表進行insert,updae,delete操作.

 2017-10-1314:58:20

2015.10.30 10:26 willem SqlServer2012 數據庫同步的兩種方式(SQL JOB + 建立鏈接服務器)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM