`
rain_2372
  • 浏览: 680927 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

用 insert into 语句将本地数据复制到远程服务器

    博客分类:
  • java
阅读更多
用 insert into 语句将本地数据复制到远程服务器。

EXEC sp_addlinkedserver
   @server='LinkServer', --远程服务器别名
@srvproduct='',
@provider='SQLOLEDB',
@datasrc='要访问的远程服务器名称'
go

exec   sp_addlinkedsrvlogin   'LinkServer','false',null,'登录用户名','登录密码'
go

declare @sql varchar(4000),@tb varchar(200)
set @tb='rj_jbxx'
set @sql=N'
delete from LinkServer.远程数据库名.dbo.['+@tb+N']
select COUNT(*) from 本地数据库名.dbo.['+@tb+N']
insert into LinkServer.远程数据库名.dbo.['+@tb+N']
select * from 本地数据库名.dbo.['+@tb+N']
select COUNT(*) from LinkServer.远程数据库名.dbo.['+@tb+N']'
execute(@sql)
go


--以后不再使用时删除链接服务器  
exec   sp_dropserver   'LinkServer','droplogins'
   --sp_helpserver --显示可用的服务器
================================================================
不同服务器数据库之间的数据操作


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

当表目标表存在时:

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

分享到:
评论

相关推荐

    sqlserver 创建触发器 远程服务器相应执行SQL语句

    这个触发器在远程服务器上监听`TestSms`表的`INSERT`操作,并将数据通过`openrowset()`函数插入到远程服务器的表`TestMess`中。 注意:如果远程服务器上的表包含自增列,那么需要取消其自增特性或者通过其他方法...

    Sqlserver2005 本地导出数据到远程实例

    - 如果数据量较大,可以考虑使用BULK INSERT命令,先将数据导出到CSV或TXT文件,然后在远程服务器上导入。 - 示例: ```sql BULK INSERT [RemoteServer].[DatabaseName].[SchemaName].[TableName] FROM 'C:\...

    跨服务器复制SQL表中数据 跨服务器复制SQL表中数据

    2. **使用OpenRowSet插入数据:**通过OpenRowSet将远程服务器上的数据插入到本地服务器的目标表中。 **示例代码:** ```sql -- 创建链接服务器(如果尚未创建) EXEC sp_addlinkedserver @server='Test', @...

    SQL操作远程数据库

    如果目标表已经存在,则可以使用 insert into 语句来插入数据。 例如: ```sql select * into 目的数据库 .. 表 from 源数据库 .. 表 ``` 三、不同服务器数据库之间的数据操作 不同服务器数据库之间的数据操作是指...

    sql server 从一个数据库复制一张表到另外一个数据库

    使用以下语句可以从远程服务器上的数据库中查询数据: select * from openrowset('SQLOLEDB', 'sql 服务器名 '; '用户名 '; '密码 ',数据库名.dbo.表名) 也可以使用以下语句将远程数据库中的表复制到当前数据库中...

    从一个数据库复制数据到另一个数据,跨服务器

    通过上述SQL语句,可以将数据从链接服务器`srv_lnk`中的表`[GDQY].[dbo].[LineCostItem]`复制到当前服务器的同名表中。这种方式简单高效,适用于需要定期进行数据同步的场景。 #### 总结 跨服务器的数据复制是...

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

    如果需要将远程服务器的数据导入到本地服务器的某个表中,可以使用以下命令: ```sql SELECT * INTO 表名 FROM ITSV.数据库名.dbo.表名 ``` #### 删除链接服务器 当不再需要某个链接服务器时,可以通过以下命令将...

    SQL语句实现跨Sql server数据库操作实例

    - 使用上面提到的SQL语句即可从本地服务器查询远程服务器上的数据。 #### 实例二:跨SQL Server实例插入数据 接下来,我们再看一个更复杂的例子,即如何将一个SQL Server实例中的数据插入到另一个SQL Server实例...

    SQL Server数据库实验指导书 实验教程 数据库实验02 通过SQL语句创建与管理数据表.pdf

    此外,实验还涵盖了修改表数据,如添加、修改、删除记录,这些可以通过`INSERT INTO`、`UPDATE`和`DELETE FROM`语句实现,但具体内容未给出示例。 整个实验旨在让学习者深入理解SQL Server 2005的数据库管理和T-SQL...

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

    当目标表已存在时,可以使用`INSERT INTO SELECT`语句将源数据库表的数据复制到目标数据库表中。例如: ```sql INSERT INTO 目的数据库..表 SELECT * FROM 源数据库..表 ``` 这会将源表的所有列和行插入到目标...

    Sql Server2000跨服务器查询数据库

    如果需要将远程服务器的数据导入到本地服务器,可以使用以下语句: **示例代码**: ```sql -- 将远程服务器的数据导入到本地表 SELECT * INTO 表名 FROM ITSV.数据库名.dbo.表名; ``` #### 删除链接服务器 当不再...

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

    总结来说,不同数据库间复制表数据的方法包括直接的SQL语句操作(如`INSERT INTO SELECT`和`SELECT INTO`),使用`OPENROWSET`,创建和使用链接服务器,以及利用备份和恢复策略。选择哪种方法取决于具体的需求,如...

    C# 本地Excel导入服务器SQL 源码下载

    2. 执行SQL命令:使用SqlCommand类,创建INSERT INTO语句,将Excel数据逐行插入到数据库表。 3. 错误处理和资源释放:确保在操作完成后关闭连接,避免资源泄露。 在导入过程中,为了提高效率,可能采用批处理的方式...

    SQLServer 2000跨服务器连接数据库1

    若需将远程服务器上的数据导入到本地服务器,可以使用如下语句: ```sql SELECT * INTO 表 FROM ITSV.数据库名.dbo.表名 ``` 当不再需要链接服务器时,可以通过`sp_dropserver`系统存储过程来删除它: ```sql ...

    跨服务器查询导入数据的sql语句

    在这个例子中,`MICS_WorkPlan_RestDays`是目标表,我们打算将数据插入到这个表中。 `SELECT * FROM`语句则用于选取源表的所有列。在这个例子中,源不是本地的表,而是远程服务器上的数据。这就是`OPENROWSET`函数...

    同步不同服务器数据库数据

    根据给定文件的信息,本文将详细解析如何在不同的服务器之间同步数据库数据,主要涉及的关键步骤包括:创建数据库链接(DBLink)、使用同义词访问远程表、构建存储过程实现数据同步以及设置定时任务来定期执行数据...

    将Excel生成SQL语句完成数据库导入.doc

    在信息技术领域,数据库管理是一项核心任务,而将数据从不同的来源导入数据库是常见的操作之一。Excel作为广泛使用的电子表格工具,其数据处理功能强大,同时也常被用作临时存储和整理数据的平台。在某些情况下,...

    SQL Server数据移动方法初探.pdf

    在使用SQL语句迁移数据时,可以通过SELECT...INTO语句将数据插入到新表中,或者使用INSERT INTO语句将数据插入到已存在的表中。需要注意的是,如果要远程连接服务器,网络传输的性能要求较高。 在数据迁移的具体...

Global site tag (gtag.js) - Google Analytics