mysql跨服务器复制表的语句_SQL Server 跨服务器 不同数据库之间复制表的数据的方法:...

不同数据库之间复制表的数据的方法:

当表目标表存在时:

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 bset b.列A = a.列Afrom openrowset (' SQLOLEDB' ,' sql服务器名' ;' 用户名' ;' 密码' ,数据库名.dbo.表名) as ainner join 本地表 bon 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 bset b.列B = a.列BFROM openquery (ITSV,' SELECT * FROM 数据库.dbo.表名' )as ainner join 本地表 bon a.列A = b.列A-- 3、opendatasource/openrowsetSELECT * 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

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

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

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地址(或者机器名)

9f5ce60f93a3cb375c0949d4513b9790.png

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

859cae021504d4fdd91b3747a797e91e.png

3、选择要导出的数据库,使用如下sql导数据:

select * into   laobao from [10.180.116.121].ynpdeicp.dbo.LaoBao

Sql解释:

select 要导入的字段 into   要导入的数据表 from [IP地址].数据库名.dbo.数据表名

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值