作業介紹 SQL SERVER的作業是一系列由SQL SERVER代理按順序執行的指定操作。作業可以執行一系列活動,包括運行Transact-SQL腳本、命令行應用程式、Microsoft ActiveX腳本、Integration Services 包、Analysis Services 命令和查 ...
作業介紹
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)...】-【常規】(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131807997-498769787.png)
註 意:鏈接伺服器IP:192.168.1.65是目標資料庫,建立這個鏈接伺服器準備直接訪問192.168.1.65的伺服器上的資料庫表。由於這裡是 SQL SERVER 所以伺服器類型選擇SQL Server。
②:選擇【安全性】設置登錄用戶和密碼,添加一個本地伺服器登錄到遠程伺服器的登錄映射。然後【確定】(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131815107-1449622028.png)
③:這時可以看到了一個192.168.1.56的鏈接伺服器。右鍵【測試連接(T)】(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131824372-105274293.png)
④:如果出現如下對話框則說明配置正確(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131831294-405646331.png)
在源資料庫伺服器上建立一個job主動的把數據push到目標資料庫里去。
⑤:新建立作業:【SQL Server 代理】-【作業】-右鍵【新建作業(N)...】
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131837669-753971863.png)
⑥:在【常規】中為作業起個名稱(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131844685-192769200.png)
⑦:點擊【步驟】,然後點擊【新建(N)...】創建作業步驟(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131852544-1638705977.png)
⑧:編輯步驟(如下圖),然後【確定】
從源資料庫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
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131910966-129053052.png)
⑨:新建作業計劃(如下圖),然後【確定】
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131919107-1971982994.png)
⑩:最終【確定】就可以了(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131927154-387131991.png)
11:執行SQL JOB,右鍵點擊剛新建的作業【PushDataToTarget】-【作業開始步驟(T)...】(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131937263-362465389.png)
12:結果出現下麵的問題(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030131954622-77671435.png)
13:然後去查看日誌右鍵點擊【PushDataToTarget】-【查看歷史記錄(V)】(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030132003419-929965285.png)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030132016372-1325858574.png)
方法二:在目標資料庫伺服器上建立一個鏈接伺服器,讓目標資料庫主動的把數據pull到源資料庫中。
1:創建鏈接伺服器 參照上方的方法,並測試鏈接成功。然後在目標數據中新建作業,如下圖
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030132031779-724638489.png)
2、新建步驟(如下圖)
從源資料庫pull數據的sql語句:
truncate table TargetData.[dbo].[TargetTable]
go
insert into TargetData.[dbo].[TargetTable ] select * from [192.168.2.200].SourceData.[dbo].[SourceTable]
go
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030132204232-2029655458.png)
3、新建計劃(如下圖)
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030132212075-666367705.png)
4、最終【確定】
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030132251950-1645658156.png)
5、右鍵點擊【PullDataFromSource】-【作業開始步驟(T)...】
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030132319654-670681726.png)
6、執行結果如下
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030132329529-1580915223.png)
7、再查看日誌如下
![](http://images2015.cnblogs.com/blog/829495/201510/829495-20151030132337419-938410347.png)
8:表明執行結果是成功的。從上面的操作中可以總結出:
鏈接伺服器的兩個特點:
1.通過鏈接伺服器不能刪除(including truncate)鏈接源伺服器的任何對像.
2:能過鏈接伺服器可以對鏈接源伺服器的表進行insert,updae,delete操作.
2017-10-1314:58:20
2015.10.30 10:26 willem SqlServer2012 資料庫同步的兩種方式(SQL JOB + 建立鏈接伺服器)