[转]SQLServer跨服务器访问数据库(openrowset/opendatasource/openquery)

1、启用Ad Hoc Distributed Queries

在使用openrowset/opendatasource前搜先要启用Ad Hoc Distributed Queries服务,因为这个服务不安全所以SqlServer默认是关闭的

启用Ad Hoc Distributed Queries的方法

SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource'

的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用

sp_configure 启用 'Ad Hoc Distributed Queries'。有关启用 'Ad Hoc Distributed Queries' 的详细

信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。
启用Ad Hoc Distributed Queries的方法,执行下面的查询语句就可以了:

exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
使用完毕后,记得一定要要关闭它,因为这是一个安全隐患,切记执行下面的SQL语句

exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure 

 

2、使用示例

 
-- 创建链接服务器 
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  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    ' ITSV  ' ,  '   ' ,  ' 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 

-- 3、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  本地表
 

 

转载于:https://www.cnblogs.com/littleCode/p/3583772.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值