SQLServer跨库操作

1、有时候获取数据需要操作其他的服务器,可以采用外链的方式进行连接获取
首先在数据库执行以下的语句创造一个外部链接:

–映射一个远程数据库
EXEC sp_addlinkedserver
‘设置的服务器名称’,
‘要添加为链接服务器的 OLE DB 数据源的产品名称,sqlserver可为空’,
‘与此数据源对应的 OLE DB 访问接口的唯一编程标识符 (PROGID)’
‘远程数据库的IP或主机名’

例:exec sp_addlinkedserver ‘SSS’, ‘’ ,‘SQLOLEDB’ ,‘10.100.92.11’

–登录远程数据库
EXEC sp_addlinkedsrvlogin
‘设置的服务器名称’,
‘确定是否通过模拟本地登录名或显式提交登录名和密码来连接到 rmtsrvname。 数据类型为 varchar(8),默认值为 TRUE’,
‘本地服务器上的登录。 locallogin 的数据类型为 sysname,默认值为 NULL。 NULL 指定此项应用于连接到 rmtsrvname 的所有本地登录。 如果不为 NULL,则 locallogin 可以是 SQL   Server 登录或 Windows 登录。 对于 Windows 登录来说,必须以直接的方式或通过已被授权访问的 Windows 组成员身份授予其访问 SQL Server 的权限’,
‘登录名’,
‘密码’

例如:exec sp_addlinkedsrvlogin 'sss ', 'false ',null, '用户名 ', '密码 ’

–查询示例
select * from sss.数据库名.dbo.表名

–导入示例
select * into 表 from sss.数据库名.dbo.表名

–以后不再使用时删除链接服务器
exec sp_dropserver 'sss ', 'droplogins ’

2、连接远程/局域网数据(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
————————————————
版权声明:本文为CSDN博主「Doris zzzzzz」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/Doris0430/article/details/88561897

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值