跨服務器查詢(轉)


服務器對象-連接服務器--
--建立連接服務器sql

exec sp_addlinkedserver 'WQJK', ' ', 'SQLOLEDB ', '遠程服務器名或ip地址 '數據庫

exec sp_addlinkedsrvlogin 'WQJK', 'false ',null, '用戶名 ', '密碼 '服務器

--查詢示例server

select * from ITSV.數據庫名.dbo.表名對象

--導入示例ip

select * into 表 from ITSV.數據庫名.dbo.表名it

--之後再也不使用時刪除連接服務器test

exec sp_dropserver 'WQJK', 'droplogins 'sed

--鏈接遠程/局域網數據(openrowset/openquery/opendatasource)date

--一、openrowset

--查詢示例

select * from openrowset( 'SQLOLEDB ', 'sql服務器名 '; '用戶名 '; '密碼 ',數據庫名.dbo.表名)

--生成本地表

select * into 表 from openrowset( 'SQLOLEDB ', 'sql服務器名 '; '用戶名 '; '密碼 ',數據庫名.dbo.表名)

--把本地表導入遠程表

insert openrowset( 'SQLOLEDB ', 'sql服務器名 '; '用戶名 '; '密碼 ',數據庫名.dbo.表名)

select *from 本地表

--更新本地表

update b

set b.列A=a.列A

from openrowset( 'SQLOLEDB ', 'sql服務器名 '; '用戶名 '; '密碼 ',數據庫名.dbo.表名)as a inner join 本地表 b

on a.column1=b.column1

--openquery用法須要建立一個鏈接

--首先建立一個鏈接建立連接服務器

exec sp_addlinkedserver 'WQJK', ' ', 'SQLOLEDB ', '遠程服務器名或ip地址 '

--查詢

select *

FROM openquery(ITSV, 'SELECT * FROM 數據庫.dbo.表名 ')

--把本地表導入遠程表

insert openquery(ITSV, 'SELECT * FROM 數據庫.dbo.表名 ')

select * from 本地表

--更新本地表

update b

set b.列B=a.列B

FROM openquery(ITSV, 'SELECT * FROM 數據庫.dbo.表名 ') as a

inner join 本地表 b on a.列A=b.列A

--三、opendatasource/openrowset

SELECT *

FROM opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登錄名;Password=密碼 ' ).test.dbo.roy_ta

--把本地表導入遠程表

insert opendatasource( 'SQLOLEDB ', 'Data Source=ip/ServerName;User ID=登錄名;Password=密碼 ').數據庫.dbo.表名

select * from 本地表

 

INSERT INTO [MediaNetDB].[dbo].[tb_AutoMedia] ([MediaClassId] ,[Name] ,[LogoPic] ,[UrlSite] ,[ReversedUrlSite] ,[MContent] ,[ModiTime] ,[ModiAdministrator] ,[AddTime] ,[AddAdministrator] ,[IsDel])select [MediaClassId] ,[Name] ,[LogoPic] ,[UrlSite] ,'' ,[MContent] ,[ModiTime] ,[ModiAdministrator] ,[AddTime] ,[AddAdministrator] ,[IsDel] FROM ITSV1.[MediaNetDB].[dbo].[MT_Media]

相關文章
相關標籤/搜索