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 Server 跨服务器 不同数据库之间复制表的数据

不同数据库之间复制表的数据的方法: 当表目标表存在时: insert into 目的数据库..表 select * from 源数据库..表   当目标表不存在时: select * into...
  • 99guo
  • 99guo
  • 2015年01月23日 16:40
  • 15475

跨服务器从一个服务器数据库一张表导数据到另一个服务器数据库另一张表中

用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('SQLOLED...

SQL Server 复制表及数据的两种方法

1、新表不存在(即复制数据的同时创建与旧表相同结构的新表): select [col1,col2,col3...] into new_table from old_table where 1=1...

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

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

服务器之间数据

  • 2012年11月24日 17:01
  • 8.45MB
  • 下载

Linux两台服务器之间复制文件及免密码登录的方法

Linux两台服务器之间复制文件及免密码登录的方法有时候搭建集群机器是,需要在多台机器中间相互拷贝文件,一种方式是同事sftp拷贝到本机,再分别拷贝到其他服务器上。这里介绍一种直接在两台服务器之间拷贝...

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

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

服务器之间使用rmi,如本地方法调用,可直接访问缓存

这几天想学习rmi的使用,网上查找的绝大部分都是在同一个项目调用的,个人感觉意义不大,不然只在同项目调用如何使rmi实现分布式。有一个链接的回答是把需要共用的接口打包,分别让服务端和客户端引用这个包,...

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

Android客户端与服务器进行数据传输时,一般会涉及到两类数据的加密情况,一类是只有创建者才能知道的数据,比如密码;另一类是其他比较重要的,但是可以逆向解密的数据。        第一类:密码类的...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:MSSQL-跨服务器之间复制数据方法
举报原因:
原因补充:

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