美文网首页
SQL跨数据库复制表数据

SQL跨数据库复制表数据

作者: 丨ChenSir丨 | 来源:发表于2020-05-25 17:20 被阅读0次

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

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

当表目标表存在时:

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 * fromITSV.数据库名.dbo.表名

--导入示例 select * into 表 fromITSV.数据库名.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本地表

--更新本地表 updateb

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本地表

--更新本地表 updateb

set b.列B=a.列B

FROM openquery(ITSV, 'SELECT * FROM 数据库.dbo.表名 ') asa

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

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

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

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

分类

此文转载收藏

相关文章

  • SQL跨数据库复制表数据

    不同服务器数据库之间的数据操作 不同数据库之间复制表的数据的方法: 当表目标表存在时: insert into 目...

  • mysql常用命令

    1、命令导出sql文件 2、命令导入sql文件 3、修改表 4、创建数据库[]可选项 5、复制表结构

  • DBLink

    DBLink作用:跨库访问。在当前数据库访问别的数据库,使用DBLink可以在当前数据库编写sql来查询别的数据库...

  • SQLServer基础

    系统数据库 SQL Server 系统自带以下数据库: master数据库master数据库用来保存SQL Ser...

  • SQL基础<一>

    前言 计划 传送门:SQL基础教程 数据库和SQL 1.数据库 提到SQL,首先必须谈到数据库,那么什么是数据库?...

  • 学习记录

    回顾了数据库制表的过程

  • iOS进阶第二天 (数据库)

    一、数据库管理系统 二、SQL语句 三、 iOS的数据库技术实现 数据库常用概念: SQL:SQL是Structu...

  • Sqlite数据库

    SQL 是用于访问和处理数据库的标准的计算机语言 SQL 能做什么? SQL 面向数据库执行查询SQL 可从数据库...

  • 数据库SQL语言入门(一)

    系列文章 数据库SQL语言入门(二)数据库SQL语言入门(三) SQL简介 SQL 是 Structure Que...

  • SQL Server跨服务器访问实例

    SQL Server 跨服务器访问实例功能非常好用,访问其他服务器可以像访问同一个数据库一样便捷。 SQL跨服务器...

网友评论

      本文标题:SQL跨数据库复制表数据

      本文链接:https://www.haomeiwen.com/subject/zptuahtx.html