精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

SQL Server實時同步更新遠程數據庫遇到的問題

數據庫 SQL Server
TableA與TableB結構相同,但數據數量不一定相同,應為有可能TableC也在更新TableB。由于數據更新不頻繁,為簡單起見想到使用了觸發器Tirgger。

工作中遇到這樣的情況,需要在更新表TableA(位于服務器ServerA 172.16.8.100中的庫DatabaseA)同時更新TableB(位于服務器ServerB 172.16.8.101中的庫DatabaseB)。

TableA與TableB結構相同,但數據數量不一定相同,應為有可能TableC也在更新TableB。由于數據更新不頻繁,為簡單起見想到使用了觸發器Tirgger。記錄一下遇到的一些問題:

1. 訪問異地數據庫

在ServerA 中創建指向ServerB的鏈接服務器,并做好賬號映射。addlinkedserver存儲過程創建一個鏈接服務器,參數詳情參見官方文檔。第1個參數LNK_ServerA是自定義的名稱;第2參數產品名稱,如果是SQL Server不用提供;第3個參數是驅動類型;第4個參數是數據源,這里寫SQL Server服務器地址

  1. exec sp_addlinkedserver 'LNK_ServerB_DatabaseB','','SQLNCLI','172.16.8.101' 

配置鏈接服務器后,默認使用同一本地賬號登陸遠程數據庫,如果賬號有不同,還需要進行賬號映射。sp_addlinkedsrvlogin參數詳情參見官方文檔。第1個參數同上;第2個參數false即使用后面參數提供的用戶密碼登陸;第3個參數null使所有本地賬號都可以使用后面的用戶密碼來登陸鏈接服務器,如果第3個參數設置為一個本地SQL Server登陸用戶名,那么只有這個用戶才可以使用遠程賬號登陸鏈接服務器;***兩個是登錄遠程服務器的用戶和密碼。

  1. exec sp_addlinkedsrvlogin 'LNK_ServerB_DatabaseB','false',null,'user','password' 

如果要刪除以上配置可以如下

  1. exec sp_droplinkedsrvlogin 'LNK_ServerB_DatabaseB',null 
  2. exec sp_dropserver 'LNK_ServerB_DatabaseB','droplogins' 

上面的配置在SQL Server Management Studio管理器里Server Objects下LinkedServers可以查詢到,如果一切鏈接正常,可以直接打開鏈接服務器上的庫表

值得注意的是以上兩個存儲過程不能出現在觸發器代碼中,而是事先在服務器ServerA中運行完成配置,否則觸發器隱式事務的要求會報錯“The procedure 'sys.sp_addlinkedserver' cannot be executed within a transaction.”

2. 配置分布式事務

SQL Server的觸發器是隱式使用事務的,鏈接服務器是遠程服務器,需要在本地服務器和遠程服務器之間開啟分布式事務處理,否則會報“The partner transaction manager has disabled its support for remote/network transactions”的錯誤。我在ServerA和ServerB中都開啟分布式事務協調器,并進行適當配置,以支持分布式事務。ServerA和ServerB都是Windows Server 2012 R2,其他版本服務器類似。

(1)首先在Services.msc中確認Distributed Transaction Coordinator已經開啟,其他版本的服務器不一定默認安裝,需要安裝windows features的方式先進行該特性的安裝。


 

(2)在服務器管理工具Administrative Tools中找到Component Services,在Local DTC中屬性Security選項卡中配置如下,打開相關安全設置,完成后會重啟服務,也有文檔稱需要重啟服務器,但是至少2012 R2不用。

(3)配置防火墻,Inbound和Outbound都打開

3. 數據庫字段text, ntext的處理

業務中表TableA中有一個Content字段是ntext類型,同步到TableB時需要對內容做一些替換處理。對于text和ntext類型是一個過時的類型,微軟官方建議用(N)VARCHAR(MAX)替換,可查閱這里。今后設計時可以考慮,這里我們考慮對ntext進行處理。

但是在觸發器中,inserted和deleted表都是不允許對text/ntext/image類型進行處理的,這里我們采用一個曲線救國的辦法,從數據庫中把記錄讀取到臨時表中,然后通過textptr和patindex函數和updatetext命令完成字符串替換處理

  1. if exists(select * from tempdb..sysobjects where id=object_id('tempdb..#temp_tablea'))  
  2.     drop table #temp_tablea 
  3. select * into #temp_tablea from TableA where ID = @ID 
  4. declare @s varchar(200),@d varchar(200) 
  5. select @s='/_target/',@d='/_replacement/' 
  6. declare @p varbinary(16),@postion int,@l int 
  7. select @p=textptr(Content),@l=len(@s),@postion=patindex('%'+@s+'%',Content)-1 from #temp_tablea 
  8. while @postion>0 
  9. begin 
  10.     updatetext #temp_tablea.Content @p @postion @l @d 
  11.     select @postion=patindex('%'+@s+'%',Content)-1 from #temp_tablea 

 

特別注意以上代碼對于text類型處理中文時會出問題,由于text存儲non-unicode的數據,patindex會將中文字符解釋為1個字符,而updatetext命令卻將中文字符解釋為2個字符。SQL Server 2005以上版本可以這樣做替換:

  1. update #temp_tablea set Content=cast(replace(cast(Content as nvarchar(max)),@s,@d) as text) 

4. 執行遠程數據庫操作

當配置鏈接服務器時,我們可以直接訪問遠程數據庫表了,如下

  1. insert into LNK_ServerB_DatabaseB.DatabaseB.dbo.TableB ... 
  2. update LNK_ServerB_DatabaseB.DatabaseB.dbo.TableB set ... 

但簡陋的SQL編輯器往往會對語法報錯,另外為方便編程,我們希望通過exec sp_executesql的方式獲得更多的靈活性。其實exec就可以直接執行sql語句,但如果有返回值就比較困難了。如下,從遠程服務器上通過ID查詢表TableB后返回Name,sp_executesql存儲過程可以使用output關鍵字定義變量為返回變量,其中@Name output為返回變量,@ID則是傳入變量。

  1. declare @sql nvarchar(500), @Name nvarchar(50),@ID nvarchar(40) 
  2. set @SQL=N'select @Name=Name from LNK_ServerB_DatabaseB.DatabaseB.dbo.TableB where ID=@ID' 
  3. exec sp_executesql @SQL,N'@Name nvarchar(50) output,@ID nvarchar(40)',@Name output,@ID 

另外exec直接執行sql語句,本質上是執行拼接后的sql字符串,有時將變量拼接進字符串會困難的多(到底需要幾個單引號),而sp_executesql則清晰多了

  1. declare @SQL nvarchar(500),@Name nvarchar(50),@Count int,@ID nvarchar(40) 
  2. set @Name=N'Cat' 
  3. set @Count=0 
  4. set @ID=N'{00000000-0000-0000-0000-000000000000}' 
  5. set @SQL=N'update TableA set Name='''+@Name+''', Count='+@Count+' where ID='''+@ID+'''' 
  6. exec(@SQL) 
  7. set @SQL=N'update TableA set Name=@Name,Count=@Count where ID=@ID' 
  8. exec sp_executesql @SQL, N'@Name nvarchar(50),@Count int,@ID nvarchar(40)',@Name,@Count,@ID 
責任編輯:武曉燕 來源: 博客園
相關推薦

2010-07-01 15:44:22

SQL Server數

2024-10-30 08:15:18

2010-05-24 18:05:12

MySQL數據庫

2009-11-18 16:16:51

Oracle數據庫

2010-08-27 09:59:51

SQL Server

2010-07-22 11:17:52

SQL Server數

2011-09-07 15:11:31

SQL Server同步

2009-05-26 10:21:07

2010-07-15 17:28:50

SQL Server

2011-07-13 16:19:54

存儲過程SQL Server數

2011-01-19 09:51:25

SQL Server

2011-08-15 16:58:34

SQL Server遠程查詢批量導入數據

2011-04-06 16:15:21

SQL Server數簡體繁體

2010-07-06 14:40:15

解決SQL Serve

2010-07-08 11:05:14

SQL Server數

2020-09-21 11:30:28

CanalMySQL數據庫

2019-10-08 15:54:42

SQL數據庫技術

2011-03-24 09:24:08

SQL Server數還原

2011-03-24 09:07:11

SQL Server數備份

2011-03-24 09:45:34

SQL Server數恢復
點贊
收藏

51CTO技術棧公眾號

免费看黄在线看| 国产精品入口尤物| 亚洲自拍偷拍精品| 咪咪网在线视频| 久久精品视频一区二区| 国产精选久久久久久| 免费网站看av| 国产一区二区三区91| 欧美区视频在线观看| 久久99中文字幕| 在线观看完整版免费| 国产东北露脸精品视频| 国产91在线播放九色快色| 小早川怜子一区二区的演员表| eeuss鲁片一区二区三区| 欧美性感美女h网站在线观看免费| 精品久久久久99| 国产九色porny| 大乳在线免费观看| 成人免费高清在线| 91精品国产综合久久久久久久久 | 国产精品三级在线观看| www.久久久| 日本精品入口免费视频| 黑丝一区二区| 日韩在线观看免费全| 日本一区二区三区网站| 欧州一区二区三区| 欧美午夜精品一区二区蜜桃| 老太脱裤让老头玩ⅹxxxx| 国产日产一区二区| 国产网站一区二区| 久久久久久高清| 亚洲国产精品二区| 国产资源精品在线观看| 国产精品久久999| 成人精品免费在线观看| 欧美日韩精品| 精品国产自在精品国产浪潮| 久久久久久久毛片| 欧美网色网址| 亚洲第一视频网站| 午夜精品免费看| 精品自拍视频| 欧美性videosxxxxx| 国产成人精品视频免费看| 成人女同在线观看| 夜夜嗨av一区二区三区四季av| 一区二区三区四区欧美| 草草影院在线观看| 国产女人水真多18毛片18精品视频 | 久久这里只有精品国产| 亚洲电影影音先锋| 另类少妇人与禽zozz0性伦| 91动漫免费网站| 日韩理论电影院| 少妇高潮久久久久久潘金莲| 亚洲色图27p| 色狮一区二区三区四区视频| 一区二区三区美女xx视频| 久久只有这里有精品| 美女久久99| 亚洲人永久免费| 日本xxxxxxxxx18| 神马电影久久| 色七七影院综合| 黄色片子在线观看| 欧美日韩视频| 8090成年在线看片午夜| 老熟妇仑乱一区二区av| 青青草成人在线观看| 成人黄色午夜影院| 国产成人精品无码高潮| 成人一区二区三区| 欧美成人综合一区| seseavlu视频在线| 国产精品久久久久久久久搜平片| 在线看视频不卡| 在线中文免费视频| 亚洲h在线观看| 无码精品国产一区二区三区免费| 日韩免费小视频| 欧美理论电影在线| 在线xxxxx| 亚洲自拍电影| 久久精品国产免费观看| 久久高清无码视频| 丝袜美腿亚洲色图| 91久久久久久久久久久久久| 成人久久久精品国产乱码一区二区 | 一区二区三区久久久| 青青草原成人网| 欧美激情不卡| 日韩av网址在线观看| 三上悠亚影音先锋| 真实国产乱子伦精品一区二区三区| 欧美成人全部免费| 黄色av一级片| 国产精品1024久久| 日韩欧美精品在线不卡| 2024最新电影在线免费观看| 狠狠色噜噜狠狠狠狠97| www.午夜av| 奇米影视777在线欧美电影观看 | 国内外成人免费视频| 韩国福利在线| 亚洲一区二区在线观看视频| 三级视频中文字幕| 国内精品免费| 日韩视频免费观看| 黄色在线视频网址| 国产精品羞羞答答xxdd| 日韩欧美精品在线不卡| av电影免费在线看| 91麻豆精品国产自产在线| 成年人网站免费在线观看| 亚洲成人99| 日韩美女中文字幕| 欧美熟女一区二区| 亚洲精品va在线观看| 亚洲最大综合网| 日韩精品导航| 欧美大片在线影院| 国产精品无码一区二区桃花视频| 久久久亚洲欧洲日产国码αv| 麻豆传媒网站在线观看| 亚洲伊人精品酒店| 国产亚洲综合久久| 天堂中文在线网| 成人精品免费网站| 欧美一区二区三区综合| 欧美男女视频| 中文字幕精品在线视频| 加勒比在线一区| 91在线国产福利| 青青草精品视频在线| 亚洲视频三区| 欧美日韩爱爱视频| 国产不卡av在线播放| 国产精品久久久久久久午夜片 | 亚洲国产欧美日本视频| 亚洲高清免费观看高清完整版| 农村黄色一级片| 国内外成人在线| 中文字幕一区二区三区四区五区| 日本黄色一区| 中文字幕日韩有码| 伊人色综合久久久| 国产精品国产三级国产专播品爱网 | 91禁在线看| 亚洲成人av片在线观看| 久久伊人成人网| 成人a区在线观看| 无码粉嫩虎白一线天在线观看| 粉嫩av一区二区| 97成人精品区在线播放| 日本视频在线观看一区二区三区| 亚洲h在线观看| 亚洲一区二区观看| 男人的天堂亚洲在线| 日本一区二区精品视频| 午夜av成人| 三级精品视频久久久久| 国产日韩一级片| 亚洲综合色视频| 中国极品少妇videossexhd| 99国内精品| 免费在线国产精品| 懂色aⅴ精品一区二区三区| 日韩一二三在线视频播| 亚洲av无码一区二区乱子伦| 午夜伊人狠狠久久| 无码人妻精品一区二区中文| 美女视频免费一区| www.18av.com| 日韩成人午夜| 国产精品丝袜久久久久久高清| 日本免费中文字幕在线| 在线播放/欧美激情| 日本一区二区不卡在线| 国产亚洲一区二区三区| 日韩欧美理论片| 在线日韩中文| 视频一区不卡| 北条麻妃在线一区二区免费播放 | 9999精品| 久久免费视频网| 国产九色在线| 精品日韩欧美一区二区| 国产剧情在线视频| 亚洲欧美日韩中文播放| 亚洲综合自拍网| 美国毛片一区二区三区| 日本丰满少妇xxxx| 色综合久久一区二区三区| 国产欧美日韩一区| 国产情侣一区二区三区| 国内外成人免费激情在线视频网站 | 成人精品视频网站| 国产无色aaa| 亚洲综合好骚| 秋霞在线一区二区| 国产精品一区二区av交换| 91青青草免费观看| 2019年精品视频自拍| 国产最新精品视频| 成人片在线看| 亚洲天堂成人在线| 日本韩国在线观看| 欧美丰满一区二区免费视频| 国产在线观看黄色| 一区二区免费视频| 亚洲欧美精品久久| 国产人久久人人人人爽| 日本黄色录像片| 国产91富婆露脸刺激对白| 亚洲精品性视频| 午夜在线视频观看日韩17c| 奇米777四色影视在线看| 日本电影一区二区| 另类小说综合网| 黑人久久a级毛片免费观看| 成人在线精品视频| 成人午夜在线| 日韩美女视频免费看| 日韩av影片| 欧美精品xxx| 一二三四区在线观看| 久久精品电影一区二区| sese一区| 伊人伊成久久人综合网小说| 色天堂在线视频| 日韩精品免费在线视频| 色wwwwww| 亚洲第一福利在线观看| 亚洲精品一区二区三区新线路| 欧美一区二区三区性视频| 一起草av在线| 欧美日韩中文字幕一区| 中文字幕 视频一区| 在线免费精品视频| 男人天堂视频在线| 色婷婷av一区二区三区之一色屋| 日韩精品手机在线| 欧美午夜美女看片| 麻豆精品久久久久久久99蜜桃| 岛国精品视频在线播放| 中文字幕亚洲精品一区| 福利微拍一区二区| 亚洲视频 欧美视频| 日本乱码高清不卡字幕| 做爰无遮挡三级| 精品视频免费看| 91精品人妻一区二区三区果冻| 欧美美女视频在线观看| 国产一区二区网站| 欧美一区二区三区在线观看视频| 精品国产av 无码一区二区三区| 制服丝袜亚洲网站| 亚洲AV午夜精品| 亚洲国产精品va在线看黑人| 手机亚洲第一页| 国产亚洲精品久久久久久| 午夜在线观看视频| 欧美老女人在线视频| 日本片在线观看| 69久久夜色精品国产69乱青草| 欧美成人黑人| 成人av在线天堂| 亚洲一二av| 久久伊人资源站| 精品日韩毛片| 福利在线小视频| 9国产精品视频| 日韩一级片播放| 黄页视频在线91| 丝袜熟女一区二区三区 | 日韩欧美国产成人精品免费| 亚洲黄一区二区三区| 国产一级精品视频| 欧美三级电影在线观看| 亚洲av无码乱码在线观看性色 | 亚洲一区二区三区香蕉| 国内精品国产成人国产三级粉色| 欧洲精品一区色| 欧美二区视频| 欧美视频第三页| 国内精品国产三级国产a久久| 亚洲成人精品在线播放| 久久精品欧美一区二区三区不卡 | 成人在线观看免费| 欧美—级a级欧美特级ar全黄 | 成人综合网网址| 日韩欧美黄色| 手机成人av在线| 性久久久久久| 亚洲午夜精品在线观看| 国产亚洲人成网站| 久久激情免费视频| 欧美色成人综合| 神马亚洲视频| 色婷婷成人综合| 成人av影院在线观看| 国产精品久久久久99| 精品综合久久88少妇激情| 影音先锋在线亚洲| 丝袜诱惑亚洲看片| 妖精视频一区二区| 亚洲色图在线播放| 五月婷婷六月婷婷| 日韩精品在线私人| 黄色的视频在线观看| 91精品视频在线| 国产一区网站| a级黄色一级片| 国产高清精品在线| 在线观看亚洲大片短视频| 五月综合激情婷婷六月色窝| 99久久久国产精品无码免费| 在线精品国产欧美| 久久sese| 久久国产精品久久| 亚洲激情在线| 中文字幕一二三| 亚洲日本一区二区| 亚洲自拍偷拍另类| 亚洲视频一区二区| 亚洲午夜天堂| 国产综合色一区二区三区| 欧美日韩岛国| 国产调教打屁股xxxx网站| 中文字幕亚洲电影| 亚洲天堂网视频| 最新的欧美黄色| 国产黄色精品| 亚洲国产一区二区三区在线| 老司机午夜精品视频在线观看| 第四色在线视频| 亚洲电影中文字幕在线观看| 亚洲成人精品女人久久久| 欧美日韩福利电影| 日韩欧美中文在线观看| 国产在线观看欧美| 国产成人在线免费观看| 久久久久亚洲AV成人| 欧美一区日韩一区| 在线看福利影| 99国产在线| 亚洲国产欧美国产综合一区| 国产精品偷伦视频免费观看了 | 真人抽搐一进一出视频| 丁香一区二区三区| xxxxxx国产| 国产手机视频精品| 国产私拍福利精品视频二区| 日韩久久在线| 久久99这里只有精品| 色欲一区二区三区精品a片| 欧美一区永久视频免费观看| 欧美xxxx免费虐| 精品欧美一区二区精品久久| 免费永久网站黄欧美| 免费看黄色三级| 欧美日韩国产精品成人| 亚洲奶水xxxx哺乳期| 亚洲曰本av电影| 亚洲欧洲一区二区天堂久久| 精品夜夜澡人妻无码av | 久久久久亚洲精品国产| 欧美挤奶吃奶水xxxxx| 欧美私人情侣网站| 国产精品国产三级国产专播品爱网 | 在线中文字幕-区二区三区四区| 国产伦精品一区二区三区免费视频 | 久久久久久久久久电影| 中文字幕+乱码+中文乱码www| www.日韩.com| 超碰成人在线免费| 人妻无码视频一区二区三区| 国产精品毛片久久久久久久| www.黄色片| 欧美在线日韩在线| 91亚洲国产| 波多野结衣视频播放| 欧美亚洲自拍偷拍| 草美女在线观看| 无码免费一区二区三区免费播放 | 九七久久人人| 国产亚洲精品美女久久久m| 秋霞影院一区二区| 黄页网站免费观看| 亚洲欧洲中文天堂| www.久久爱.com| 日韩av片在线看| 亚洲啪啪综合av一区二区三区| 亚洲欧洲视频在线观看| 成人网址在线观看| 久久免费黄色| 麻豆视频在线观看| 在线观看视频亚洲|