MSSQL-跨服务器之间复制数据方法

转载 2015年07月06日 17:46:28

开启SQL相关配置

SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource' 的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用 sp_configure 启用 'Ad Hoc Distributed Queries'。有关启用 'Ad Hoc Distributed Queries' 的详细信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。

1.开启Ad Hoc Distributed Queries组件,在sql查询编辑器中执行如下语句:
 
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure

    2.关闭Ad Hoc Distributed Queries组件,在sql查询编辑器中执行如下语句:


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

---------------------------------

=====示例=========

--查询远程
--select * from openrowset( 'SQLOLEDB', '166.62.xx.xx'; 'userid'; 'pwd', databaseName.dbo.admin)
/* */
--insert openrowsetopenrowset( 'SQLOLEDB', '166.62.xx.xx'; 'userid'; 'pwd', databaseName.dbo.admin)
select count(id) from carsets_co_uk_server.dbo.ProContent as spro where spro.ProductItemNo not in(select tpro.ProductItemNo from openrowset( 'SQLOLEDB', '166.62.xx.xx'; 'userid'; 'pwd', databaseName.dbo.admin) as tpro)



----复制查询方法---

不同服务器数据库之间的数据操作

>>方法一
--创建链接服务器
exec sp_addlinkedserver  'ITSV ', '', 'SQLOLEDB', '远程服务器名或ip地址'
exec sp_addlinkedsrvlogin'ITSV ', 'false',null,'用户名 ', '密码'

--查询示例
select * from ITSV.数据库名.dbo.表名

--导入示例
select * intofrom ITSV.数据库名.dbo.表名

--以后不再使用时删除链接服务器
exec sp_dropserver 'ITSV ', 'droplogins'


--- 方法二----

--连接远程/局域网数据(openrowset/openquery/opendatasource)
--
1、openrowset

--查询示例
select * fromopenrowset('SQLOLEDB ', 'sql服务器名'; '用户名'; '密码',数据库名.dbo.表名)

--生成本地表
select * intofrom openrowset( 'SQLOLEDB ','sql服务器名 '; '用户名'; '密码',数据库名.dbo.表名)

--把本地表导入远程表
insert openrowset( 'SQLOLEDB ','sql服务器名 '; '用户名'; '密码',数据库名.dbo.表名)
select *from 本地表

--更新本地表
update b
set b.列A=a.列A
from openrowset( 'SQLOLEDB ','sql服务器名 '; '用户名'; '密码',数据库名.dbo.表名)as ainner 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
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




相关文章推荐

SQL总结之跨数据库服务器之间的数据访问(MSSQL)

跨数据服务器访问数据,有什么用呢?它主要用于不同系统间的在数据库层面的数据同步。 MSSQL可以创建对其它数据库的链接,像访问本地数据库一样访问远程数据库中对象(表、存储过程等),创建链接的方式有两种...

本地电脑与远程服务器之间不能复制粘贴解决方法

(1)打开本机的远程桌面连接图标按照下图所示,勾选以下项目: (2)在服务器上打开任务管理器,查看进程,有 rdpclip.exe 进程。通常,只要存在该进程,就可以在本机和远程服务器之...

本地电脑与远程服务器之间不能复制粘贴解决方法

刚才用远程桌面登陆服务器,突然发现不能在本地电脑和远程服务器之间粘贴文本了,即不能从本机复制文本粘贴到服务器,也不能从服务器复制文本粘贴到本机。   目前针对这种情况有以下几种方法解决: ...

本地电脑与远程服务器之间不能复制粘贴解决方法

刚才用远程桌面登陆服务器,突然发现不能在本地电脑和远程服务器之间粘贴文本了,即不能从本机复制文本粘贴到服务器,也不能从服务器复制文本粘贴到本机。 目前针对这种情况有以下几种方法解决: 1.打开...

服务器之间数据

  • 2012-11-24 17:01
  • 8.45MB
  • 下载

Android:客户端和服务器之间传输数据加密

Android客户端与服务器进行数据传输时,一般会涉及到两类数据的加密情况,一类是只有创建者才能知道的数据,比如密码;另一类是其他比较重要的,但是可以逆向解密的数据。        第一类:密码...

关于两台服务器之间SQL数据互访

方法一 不同服务器数据库之间的数据操作 --创建链接服务器  exec sp_addlinkedserver 'ITSV ', ' ', 'SQLOLEDB ', '远程服务器名或i...

Android:客户端和服务器之间传输数据加密

Android客户端与服务器进行数据传输时,一般会涉及到两类数据的加密情况,一类是只有创建者才能知道的数据,比如密码;另一类是其他比较重要的,但是可以逆向解密的数据。        第一类:密码...

通过rsync+inotify实现服务器之间数据的实时备份

在上一篇博客中,我们只使用了rsync来实现数据的备份,但却不能做到实时,因为守护进程触发和执行有一段的时间间隔,如果对于数据量大的网站来说,一旦崩溃,就很难做到数据的完整性。在本篇文章中我们使用rs...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)