您当前的位置:首页 > sqlserver数据库 > 文章详情

SQL server 2005,sql server 2008 不同的服务器不同的数据库复制表和表数据的方法

2016-02-096513人围观

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

当表目标表存在时: 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 本地表 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 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 ----------------------------------------------------------------------------------------------------------------------------------- 好吧,如果上面看得烦下面有个更容易理解的例子: 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.数据表名
         

文章评论

热门评论
暂无评论