SQLServer中跨服務器跨數據庫之間的數據操作


首先必須理解一個概念:

select * from sys.servers         (查看系統表,看原來的服務器名)

要想跨域就必須在以上信息中可以檢索到!

怎樣添加?

 

--創建鏈接服務器 
exec sp_addlinkedserver   'ITSV '' ''SQLOLEDB ''遠程服務器名或ip地址 ' 
exec sp_addlinkedsrvlogin  'ITSV ''false ',null'用戶名 ''密碼 ' 
 
--查詢示例 
select from ITSV.數據庫名.dbo.表名 
 
--導入示例 
select into 表 from ITSV.數據庫名.dbo.表名 
 
--以后不再使用時刪除鏈接服務器 
exec sp_dropserver  'ITSV ''droplogins ' 
 
--連接遠程/局域網數據(openrowset/openquery/opendatasource) 
--1、openrowset 
 
--查詢示例 
select  from  openrowset(  'SQLOLEDB ' 'sql服務器名 ' '用戶名 ' '密碼 ' ,數據庫名.dbo.表名) 
 
--生成本地表 
select  into  表  from  openrowset(  'SQLOLEDB ' 'sql服務器名 ' '用戶名 ' '密碼 ' ,數據庫名.dbo.表名) 
 
--把本地表導入遠程表 
insert  openrowset(  'SQLOLEDB ' 'sql服務器名 ' '用戶名 ' '密碼 ' ,數據庫名.dbo.表名) 
select  * from  本地表 
 
--更新本地表 
update 
set  b.列A=a.列A 
  from  openrowset(  'SQLOLEDB ' 'sql服務器名 ' '用戶名 ' '密碼 ' ,數據庫名.dbo.表名) as  inner  join  本地表 b 
on  a.column1=b.column1 
 
--openquery用法需要創建一個連接 
 
--首先創建一個連接創建鏈接服務器 
exec  sp_addlinkedserver    'ITSV ' ' ' 'SQLOLEDB ' '遠程服務器名或ip地址 ' 
--查詢 
select 
FROM  openquery(ITSV,   'SELECT *  FROM 數據庫.dbo.表名 '
--把本地表導入遠程表 
insert  openquery(ITSV,   'SELECT *  FROM 數據庫.dbo.表名 '
select  from  本地表 
--更新本地表 
update 
set  b.列B=a.列B 
FROM  openquery(ITSV,   'SELECT * FROM 數據庫.dbo.表名 ' as  a  
inner  join  本地表 b  on  a.列A=b.列A 
 
--3、opendatasource/openrowset 
SELECT   
FROM    opendatasource(  'SQLOLEDB ' ,   'Data Source=ip/ServerName;User ID=登陸名;Password=密碼 '  ).test.dbo.roy_ta 
--把本地表導入遠程表 

 

 

測試演示:

user master;

exec sp_addlinkedserver   '41f0bcc ', ' ', 'SQLOLEDB ', '192.168.7.21' 
exec sp_addlinkedsrvlogin  '41f0bcc ', 'false ',null, 'sa ', 'q1w2e3e3r45tr4t5' 

select * from [41f0bcc].eStoreDB.dbo.V_standard_ORG


免責聲明!

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



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