您的位置:首页 > 数据库

SQL Server 跨服务器 不同数据库之间复制表的数据

2017-04-09 17:18 881 查看
不同数据库之间复制表的数据的方法:

当表目标表存在时:

insert into 目的数据库..表 select * from 源数据库..表  

当目标表不存在时:

select * into 目的数据库..表 from 源数据库..表

--如果在不同的SQL之间: 

insert into openrowset('sqloledb','目的服务器名';'sa';'',目的数据库.dbo.表) 

select * from 源数据库..表 

-- 创建链接服务器 
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 本地表

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

注意:某些时候会出现未开启Ad Hoc,使用下面的语句开启使用

启用Ad Hoc Distributed Queries:
exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
    使用完成后,关闭Ad Hoc Distributed Queries:
exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure

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

好吧,如果上面看得烦下面有个更容易理解的例子:

Exec sp_droplinkedsrvlogin DBVIP,Null

Exec sp_dropserver DBVIP

EXEC sp_addlinkedserver

      @server='DBVIP',--被访问的服务器别名 

      @srvproduct='',

      @provider='SQLOLEDB',

      @datasrc='Server2'   --要访问的服务器

EXEC sp_addlinkedsrvlogin 

     'DBVIP', --被访问的服务器别名

     'false', 

     NULL, 

     'sa', --帐号

     'thankyoubobby' --密码

Select   *   from DBVIP.pubs.dbo.orders   

/////////////////////////////Oracle////////////////////////////

Exec sp_droplinkedsrvlogin demo,Null

Exec sp_dropserver demo
Go

EXEC sp_addlinkedserver 

        @server ='demo',

        @srvproduct='Oracle',

   @provider='MSDAORA', 

   @datasrc='ServiceName'

EXEC sp_addlinkedsrvlogin 

     'demo', 

     'false', 

     NULL, 

     'userid', 

     'password' 

go

SELECT * FROM OPENQUERY(demo ,'select * from tbdemo' )

UPDATE OPENQUERY (demo, 'SELECT id FROM tbdemo WHERE id = 101') 

SET name = 'hello';

INSERT OPENQUERY (demo, 'SELECT id FROM tbdemo')

VALUES ('hello');

DELETE OPENQUERY (demo, 'SELECT id FROM tbdemo WHERE name = ''hello''');

 

-------------------------------------------具体例子------------------------------------------------------------

if   exists(select   1   from   master.dbo.sysservers   where   srvname   =   'test')   

begin   

exec   sp_droplinkedsrvlogin     'test','sa'   

exec   sp_dropserver     'test'   

end  

--建立连接服务器 

EXEC sp_addlinkedserver 'test', 'ms','SQLOLEDB', '192.168.1.99'

exec sp_addlinkedsrvlogin 'test','false',null,'sa',''

select * from test.db_film.dbo.T_film

go

if   exists(select   1   from   master.dbo.sysservers   where   srvname   =   'test')   

begin   

exec   sp_droplinkedsrvlogin     'test','sa'   

exec   sp_dropserver     'test'   

end  

go

 

方法二:

1、新建一个连接服务器,连接到你要导入的服务器的IP地址(或者机器名)



2、点击安全性,使用此安全上下文建立连接,输入数据库服务器的用户名和密码



3、选择要导出的数据库,使用如下sql导数据:
select * into   laobao from [10.180.116.121].ynpdeicp.dbo.LaoBao
Sql解释:
select 要导入的字段 into   要导入的数据表 from [IP地址].数据库名.dbo.数据表名
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: