程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> MSSQL2008 >> 深刻SqlServer2008 數據庫同步的兩種方法(Sql JOB)的剖析引見

深刻SqlServer2008 數據庫同步的兩種方法(Sql JOB)的剖析引見

編輯:MSSQL2008

深刻SqlServer2008 數據庫同步的兩種方法(Sql JOB)的剖析引見。本站提示廣大學習愛好者:(深刻SqlServer2008 數據庫同步的兩種方法(Sql JOB)的剖析引見)文章只能為提供參考,不一定能成為您想要的結果。以下是深刻SqlServer2008 數據庫同步的兩種方法(Sql JOB)的剖析引見正文


上面引見的就是數據庫同步的兩種方法:

  1、SQL JOB的方法 

  sql Job的方法同步數據庫就是經由過程SQL語句,將一個數據源中的數據同步到目的數據庫中。特色是它可以靈巧的經由過程SQL的方法停止數據庫之間的同步操作。可以在制訂的時光時光作為義務籌劃主動履行。缺陷是須要寫SQL來停止操作。既然是數據庫之間的同步就觸及到數據庫之間的銜接。樹立銜接是同步的第一步。SQL Server樹立銜接可以經由過程體系存儲進程樹立【能否還有其他方法,我還不清晰】。存儲進程有以下幾個:sp_droplinkedsrvlogin、sp_dropserver、sp_addlinkedserver、sp_addlinkedsrvlogin。後面兩個是刪除數據庫之間銜接的,後兩個是樹立數據庫之間銜接的。

    刪除銜接存儲進程參數用法以下:

a)sp_droplinkedsrvlogin

語法

sp_addlinkedsrvlogin [ @rmtsrvname = ] 'rmtsrvname'
    [ , [ @useself = ] 'useself' ]
    [ , [ @locallogin = ] 'locallogin' ]
    [ , [ @rmtuser = ] 'rmtuser' ]
    [ , [ @rmtpassword = ] 'rmtpassword' ]

參數

[@rmtsrvname =] 'rmtsrvname'

是運用登錄映照的鏈接辦事器稱號。rmtsrvname 的數據類型為 sysname,沒有默許設置。

[@useself =] 'useself'

決議用於銜接到長途辦事器的登錄稱號。useself 的數據類型為 varchar(8),默許設置為 TRUE。true 值指定 SQL Server 驗證的登錄應用其本身的憑證以銜接到 rmtsrvname,而疏忽 rmtuserrmtpassword 參數。false 值指定 rmtuserrmtpassword 參數用來銜接到特定 localloginrmtsrvname。假如 rmtuserrmtpassword 也設置為 NULL,則銜接鏈接辦事器不需應用任何登錄或暗碼。關於 Windows NT 身份驗證登錄而言,useself 為 true 則有效,除非 Microsoft Windows NT® 情況支撐平安帳戶拜托,而且,供給法式支撐 Windows 身份驗證(此時不再須要創立值為 true 的映照,不外創立依然有用)。

[ @locallogin =] 'locallogin'

當地辦事器上的登錄。locallogin 的數據類型為 sysname,默許設置為 NULL。NULL 值指定此條目將運用於一切銜接到 rmtsrvname 的當地登錄。假如值不為 NULL,則 locallogin 可所以一個 SQL Server 登錄或 Windows NT 用戶。必需授與 Windows NT 用戶直接拜訪 SQL Server 或經由過程其作為已授與拜訪權限的組的成員來拜訪 SQL Server 的權限。

[@rmtuser =] 'rmtuser'

useself 為 false 時,用來銜接 rmtsrvname 的用戶名,rmtuser 的數據類型為 sysname,默許設置為 NULL。

[@rmtpassword =] 'rmtpassword'

rmtuser 相干的暗碼。rmtpassword 的數據類型為 sysname,默許設置為 NULL。

前往代碼值

0(勝利)或 1(掉敗)

正文:

當用戶登錄到當地辦事器並履行散布式查詢,以拜訪鏈接辦事器上的表時,當地辦事器必需登錄鏈接辦事器上,代表該用戶拜訪該表。應用 sp_addlinkedsrvlogin 來指定當地辦事器登錄鏈接辦事器的登錄憑證。

當地辦事器上一切登錄和鏈接辦事器上的長途登錄之間的默許映照經由過程履行 sp_addlinkedserver 主動創立。默許映照解釋銜接到鏈接辦事器代表的登錄時,SQL Server 應用當地登錄的用戶憑證(同等於將鏈接辦事器的 @useself 設置為 true 時履行 sp_addlinkedsrvlogin)。應用 sp_addlinkedsrvlogin 只可以更改特定的當地辦事器的默許映照或添加新映照。若要刪除默許映照或任何其它映照,請應用 sp_droplinkedsrvlogin。

當一切以下前提存在時,SQL Server 可以主動地應用正在收回查詢的用戶的 Windows NT 平安憑證(Windows NT 用戶稱號和暗碼),以銜接到鏈接辦事器,而不是必需應用 sp_addlinkedsrvlogin 創立一個預設的登錄映照。

  用法示例:

EXEC sp_droplinkedsrvlogin 'DBLink',Null

b)sp_dropserver

從當地 Microsoft® SQL Server™ 上的已知長途和鏈接辦事器列表中刪除辦事器。

語法

sp_dropserver [ @server = ] 'server'
    [ , [ @droplogins = ] { 'droplogins' | NULL} ]

參數

[@server =] 'server'

將被刪除的辦事器。server 的數據類型為 sysname,沒有默許值。server 必需曾經存在。

[@droplogins =] 'droplogins' | NULL

指明假如指定了 droplogins,那末關於 server,那些相干的長途及鏈接辦事器登錄也將被刪除。@droplogins 的數據類型為 char(10),帶有默許值 NULL。

前往代碼值

0(勝利)或 1(掉敗)

正文

假如某個辦事器有相干的長途及鏈接辦事器登錄條目,當在該辦事器上運轉 sp_dropserver 時,會招致一條毛病信息,該新聞解釋:在刪除長途或鏈接辦事器之前,必需先刪除相干的登錄。當刪除辦事器時,為了刪除辦事器的一切長途及鏈接辦事器登錄,請應用 droplogins 參數。

不克不及在用戶界說的事務內履行 sp_dropserver。

權限

只要 sysadmin 或 setupadmin 固定辦事器腳色的成員才可以履行 sp_dropserver。

用法示例:

EXEC sp_dropserver 'DBLink'

    樹立銜接存儲進程參數用法以下:

a)sp_addlinkedserver

創立一個鏈接的辦事器,使其許可對散布式的、針對 OLE DB 數據源的異類查詢停止拜訪。在應用 sp_addlinkedserver 創立鏈接的辦事器以後,此辦事器便可以履行散布式查詢。假如鏈接辦事器界說為 Microsoft® SQL Server™,則可履行長途存儲進程。

語法

sp_addlinkedserver [ @server = ] 'server'
    [ , [ @srvproduct = ] 'product_name' ]
    [ , [ @provider = ] 'provider_name' ]
    [ , [ @datasrc = ] 'data_source' ]
    [ , [ @location = ] 'location' ]
    [ , [ @provstr = ] 'provider_string' ]
    [ , [ @catalog = ] 'catalog' ]

參數

[ @server = ] 'server'

要創立的鏈接辦事器的當地稱號,server 的數據類型為 sysname,沒有默許設置。

假如有多個 SQL Server 實例,server 可認為 servername\instancename。此鏈接的辦事器能夠會被援用為上面示例的數據源:

SELECT *FROM [servername\instancename.]pubs.dbo.authors. 

假如未指定 data_source,則辦事器為該實例的現實稱號。

[ @srvproduct = ] 'product_name'

要添加為鏈接辦事器的 OLE DB 數據源的產物稱號。product_name 的數據類型為 nvarchar(128),默許設置為 NULL。假如是 SQL Server,則不須要指定 provider_namedata_sourcelocationprovider_string 和目次。

[ @provider = ] 'provider_name'

與此數據源絕對應的 OLE DB 供給法式的獨一法式標識符 (PROGID)。provider_name 關於裝置在以後盤算機上指定的 OLE DB 供給法式必需是獨一的。provider_name 的數據類型為nvarchar(128),默許設置為 NULL。OLE DB 供給法式應當用給定的 PROGID 在注冊表中注冊。

[ @datasrc = ] 'data_source'

由 OLE DB 供給法式說明的數據源稱號。data_source 的數據類型為 nvarchar(4000),默許設置為 NULL。data_source 被看成 DBPROP_INIT_DATASOURCE 屬性傳遞以便初始化 OLE DB 供給法式。

當鏈接的辦事器針關於 SQL Server OLE DB 供給法式創立時,可以依照 servername\instancename 的情勢指定 data_source,它可以用來銜接到運轉於特定盤算機上的 SQL Server 的特定實例上。servername 是運轉 SQL Server 的盤算機稱號,instancename 是用戶將被銜接到的特定 SQL Server 實例的稱號。

[ @location = ] 'location'

OLE DB 供給法式所說明的數據庫的地位。location 的數據類型為 nvarchar(4000),默許設置為 NULL。location 作為 DBPROP_INIT_LOCATION 屬性傳遞以便初始化 OLE DB 供給法式。

[ @provstr = ] 'provider_string'

OLE DB 供給法式特定的銜接字符串,它可標識獨一的數據源。provider_string 的數據類型為 nvarchar(4000),默許設置為 NULL。Provstr 作為 DBPROP_INIT_PROVIDERSTRING 屬性傳遞以便初始化 OLE DB 供給法式。

當針對 Server OLE DB 供給法式供給了鏈接辦事器後,可將 SERVER 症結字用作 SERVER=servername\instancename 來指定實例,以指定特定的 SQL Server 實例。servername 是 SQL Server 在其上運轉的盤算機稱號,instancename 是用戶銜接到的特定的 SQL Server 實例稱號。

[ @catalog = ] 'catalog'

樹立 OLE DB 供給法式的銜接時所應用的目次。catalog 的數據類型為sysname,默許設置為 NULL。catalog 作為 DBPROP_INIT_CATALOG 屬性傳遞以便初始化 OLE DB 供給法式。

前往代碼值

0(勝利)或 1(掉敗)

成果集

假如沒有指定參數,則 sp_addlinkedserver 前往此新聞:

Procedure 'sp_addlinkedserver' expects parameter '@server', which was not supplied.

應用恰當 OLE DB 供給法式和參數的 sp_addlinkedserver 前往此新聞:

Server added.
用法示例:
EXEC sp_addlinkedserver 'DBLink', ' ', 'SQLOLEDB', "10.0.222.12"

b)sp_addlinkedsrvlogin

創立或更新當地 Microsoft® SQL Server™ 實例上的登錄與鏈接辦事器上長途登錄之間的映照。

語法

sp_addlinkedsrvlogin [ @rmtsrvname = ] 'rmtsrvname'
    [ , [ @useself = ] 'useself' ]
    [ , [ @locallogin = ] 'locallogin' ]
    [ , [ @rmtuser = ] 'rmtuser' ]
    [ , [ @rmtpassword = ] 'rmtpassword' ]

參數

[@rmtsrvname =] 'rmtsrvname'

是運用登錄映照的鏈接辦事器稱號。rmtsrvname 的數據類型為 sysname,沒有默許設置。

[@useself =] 'useself'

決議用於銜接到長途辦事器的登錄稱號。useself 的數據類型為 varchar(8),默許設置為 TRUE。true 值指定 SQL Server 驗證的登錄應用其本身的憑證以銜接到


 rmtsrvname,而疏忽 rmtuserrmtpassword 參數。false 值指定 rmtuserrmtpassword 參數用來銜接到特定 localloginrmtsrvname


假如 rmtuserrmtpassword 也設置為 NULL,則銜接鏈接辦事器不需應用任何登錄或暗碼。關於 Windows NT 身份驗證登錄而言,useself 為 true 則有效,


除非 Microsoft Windows NT® 情況支撐平安帳戶拜托,而且,供給法式支撐 Windows 身份驗證(此時不再須要創立值為 true 的映照,不外創立依然有用)。

[ @locallogin =] 'locallogin'

當地辦事器上的登錄。locallogin 的數據類型為 sysname,默許設置為 NULL。NULL 值指定此條目將運用於一切銜接到 rmtsrvname 的當地登錄。假如值不為 NULL,


locallogin 可所以一個 SQL Server 登錄或 Windows NT 用戶。必需授與 Windows NT 用戶直接拜訪 SQL Server 或經由過程其作為已授與拜訪權限的組的成員來拜訪


SQL Server 的權限。


[@rmtuser =] 'rmtuser'


useself 為 false 時,用來銜接 rmtsrvname 的用戶名,rmtuser 的數據類型為 sysname,默許設置為 NULL。


[@rmtpassword =] 'rmtpassword'


rmtuser 相干的暗碼。rmtpassword 的數據類型為 sysname,默許設置為 NULL。

前往代碼值

0(勝利)或 1(掉敗)

正文

當用戶登錄到當地辦事器並履行散布式查詢,以拜訪鏈接辦事器上的表時,當地辦事器必需登錄鏈接辦事器上,代表該用戶拜訪該表。應用 sp_addlinkedsrvlogin 來指定當地服


務器登錄鏈接辦事器的登錄憑證。

當地辦事器上一切登錄和鏈接辦事器上的長途登錄之間的默許映照經由過程履行 sp_addlinkedserver 主動創立。默許映照解釋銜接到鏈接辦事器代表的登錄時,SQL Server


應用當地登錄的用戶憑證(同等於將鏈接辦事器的 @useself 設置為 true 時履行 sp_addlinkedsrvlogin)。應用 sp_addlinkedsrvlogin 只可以更改特定的當地辦事器


的默許映照或添加新映照。若要刪除默許映照或任何其它映照,請應用 sp_droplinkedsrvlogin。

當一切以下前提存在時,SQL Server 可以主動地應用正在收回查詢的用戶的 Windows NT 平安憑證(Windows NT 用戶稱號和暗碼),以銜接到鏈接辦事器,而不是必需應用

sp_addlinkedsrvlogin 創立一個預設的登錄映照。

    應用 Windows 身份驗證形式,用戶銜接到 SQL Server。

    在客戶端和發送辦事器上平安帳戶拜托是可用的。

    供給法式支撐 Windows 身份驗證形式(例如,運轉於 Windows NT 上的 SQL Server)。

應用映照(此映照經由過程在當地 SQL Server 上履行 sp_addlinkedsrvlogin 界說)的鏈接辦事器履行身份驗證後,長途數據庫中零丁對象的權限由鏈接辦事器決議,


而不是由當地辦事器決議。

不克不及從用戶界說的事務中履行 sp_addlinkedsrvlogin。

權限

只要 sysadmin 和 securityadmin 固定辦事器腳色的成員才可以履行 sp_addlinkedsrvlogin。

用法示例EXEC sp_addlinkedsrvlogin 'DBLink', 'false',null, 'ILM', '111111

引見完樹立銜接的方法,上面正式引見SQL JOB的開辟。直接用步調引見了。
a)新建功課。以下圖:

a、  新建功課。以下圖:

b、  點擊【新建功課】對話框的【慣例】選項卡,填寫 SQL JOB的稱號。以下圖

c、  點擊【新建功課】對話框的【步調】選項卡,填寫 步調稱號。




d、  停止功課的第一個步調------樹立數據庫銜接操作。以下圖:


e、  停止功課的第下一個步調。以下圖:

e、設置功課履行籌劃

f、點擊肯定,完成SQL JOB的開辟。

g、完成後功課上面就多了剛開辟的功課。以下:

h、功課制造完成後,可以立刻讓它履行。假如不讓它履行,它也會在依照制訂頻率履行。測試功課:




  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved