[SQL SERVER] 跨库查询--分布式查询


用openrowset连接远程SQL或插入数据

--如果只是临时访问,可以直接用openrowset

--查询示例

SELECT * FROM OPENROWSET('SQLOLEDB','Data Source=ServerName;User ID=MyUID;Password=MyPass',数据库名.dbo.表名)

--导入示例

SELECT * INTO 表 FROM OPENROWSET('SQLOLEDB','Data Source=ServerName;User ID=MyUID;Password=MyPass',数据库名.dbo.表名)

--创建链接服务器

EXEC SP_ADDLINKEDSERVER 'srv_lnk','','SQLOLEDB','远程服务器名或ip地址'
EXEC SP_ADDLINKEDSRVLOGIN 'srv_lnk','false',null,'用户名','密码'
GO

--查询示例

SELECT * FROM srv_lnk.数据库名.dbo.表名

--导入示例

SELECT * INTO 表 FROM srv_lnk.数据库名.dbo.表名

--以后不再使用时删除链接服务器

EXEC SP_DROPSERVER 'srv_lnk','droplogins'
GO

--下面的示例访问来自某个表的数据,该表在 SQL Server 的另一个实例中。

SELECT * FROM OPENDATASOURCE('SQLOLEDB','Data Source=ServerName;User ID=MyUID;Password=MyPass').Northwind.dbo.Categories

下面是个查询的示例,它通过用于 Jet 的 OLE DB 提供程序查询 Excel 电子表格。

SELECT * FROM OPENDATASOURCE('Microsoft.Jet.OLEDB.4.0','Data Source="c:Financeaccount.xls";User ID=Admin;Password=;Extended properties=Excel 5.0')...xactions

如果只是偶尔使用 就用opendatasource/openrowset, 固定的频繁使用建linked server

转载于:https://www.cnblogs.com/Magicworks/archive/2011/11/26/2264192.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值