- 浏览: 683225 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
Hippyqq:
谢谢很有用,
java中遍历MAP的几种方法 -
XSoftlab:
超详细。。。Java map 详解 - 用法、遍历、排序、常用 ...
java中遍历MAP的几种方法 -
bobo22:
importnet.sf.fmj.ui.application ...
java来调用电脑视频摄像头拍照进行截图 -
qq981378640:
#include <stdio.h>
int ...
c语言中unsigned类型和普通类型间的转换 -
qq981378640:
楼主你这样有点复杂了,直接这样写更好更方便
#include ...
c语言中unsigned类型和普通类型间的转换
用 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
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
发表评论
-
java应用CPU占用100%内存泄漏分析总结
2017-11-28 08:46 575转; http://www.blogjava.net/hank ... -
Java Mysql存取Blob数据
2014-10-21 12:54 1557当数据库字段为blob类型时 ,我们如果使用PreparedS ... -
关于日志的等级 的配置
2014-07-02 16:49 634#这里定义能显示到的最低级别,若定义到INFO级别,则看不到D ... -
Extjs中如何在一行textfield后面加几个字
2014-04-14 16:38 1531{ fieldLabel : '输入框', xtype : ' ... -
数据库中图片的操作(字节流的操作)
2013-12-09 17:26 830package com.fww.util; import j ... -
java 获得本地ip
2013-11-28 18:04 895Enumeration allNetInterfaces = ... -
java多线程下载的例子代码
2013-09-09 16:16 0java多线程下载的例子代码 import java.io.I ... -
java来调用电脑视频摄像头拍照进行截图
2013-09-09 15:34 10411packagecom.pengo.capture; i ... -
java中lucene解析word工具类
2013-09-09 15:32 1057java中lucene解析word工具类(读取word文档并查 ... -
Java 向oracle插入百万数据
2013-09-09 15:30 1553这里的表是没加索引的 ... -
java 写 excel
2013-08-28 10:29 983import java.io.FileOutputStream ... -
list 排序
2013-06-20 20:43 1087import java.util.Collections; i ... -
java抓取网络图片放到本地
2013-05-07 10:39 4301import java.io.BufferedInputStr ... -
java代码发送JSON格式的httpPOST请求
2013-05-06 13:41 20390package com.test; import java. ... -
java操作excel(HSSF样式) .
2013-04-15 15:06 1983java操作excel(HSSF样式一) import ja ... -
JAVA+Ftpclient操作
2013-03-07 16:35 6583最近再做个ftp上传、下载的项目,用到的包是sun.net.f ... -
自动消除文本框中的空格;js清除空格问题,去除空格问题
2013-03-01 11:22 6321自动消除文本框中的空格;js清除空格问题,去除空格问题 要完成 ... -
java执行Linux命令 .
2012-12-26 09:29 1303/** * 修改Linux目录权限 * @param ... -
UUID生成类
2012-12-16 18:18 2498import java.net.InetAddress; im ... -
java反射获得类的字段和值
2012-12-10 17:26 1640import java.util.HashMap; impo ...
相关推荐
这个触发器在远程服务器上监听`TestSms`表的`INSERT`操作,并将数据通过`openrowset()`函数插入到远程服务器的表`TestMess`中。 注意:如果远程服务器上的表包含自增列,那么需要取消其自增特性或者通过其他方法...
- 如果数据量较大,可以考虑使用BULK INSERT命令,先将数据导出到CSV或TXT文件,然后在远程服务器上导入。 - 示例: ```sql BULK INSERT [RemoteServer].[DatabaseName].[SchemaName].[TableName] FROM 'C:\...
使用以下语句可以从远程服务器上的数据库中查询数据: select * from openrowset('SQLOLEDB', 'sql 服务器名 '; '用户名 '; '密码 ',数据库名.dbo.表名) 也可以使用以下语句将远程数据库中的表复制到当前数据库中...
2. **使用OpenRowSet插入数据:**通过OpenRowSet将远程服务器上的数据插入到本地服务器的目标表中。 **示例代码:** ```sql -- 创建链接服务器(如果尚未创建) EXEC sp_addlinkedserver @server='Test', @...
如果目标表已经存在,则可以使用 insert into 语句来插入数据。 例如: ```sql select * into 目的数据库 .. 表 from 源数据库 .. 表 ``` 三、不同服务器数据库之间的数据操作 不同服务器数据库之间的数据操作是指...
通过上述SQL语句,可以将数据从链接服务器`srv_lnk`中的表`[GDQY].[dbo].[LineCostItem]`复制到当前服务器的同名表中。这种方式简单高效,适用于需要定期进行数据同步的场景。 #### 总结 跨服务器的数据复制是...
如果需要将远程服务器的数据导入到本地服务器的某个表中,可以使用以下命令: ```sql SELECT * INTO 表名 FROM ITSV.数据库名.dbo.表名 ``` #### 删除链接服务器 当不再需要某个链接服务器时,可以通过以下命令将...
- 使用上面提到的SQL语句即可从本地服务器查询远程服务器上的数据。 #### 实例二:跨SQL Server实例插入数据 接下来,我们再看一个更复杂的例子,即如何将一个SQL Server实例中的数据插入到另一个SQL Server实例...
在这个例子中,`MICS_WorkPlan_RestDays`是目标表,我们打算将数据插入到这个表中。 `SELECT * FROM`语句则用于选取源表的所有列。在这个例子中,源不是本地的表,而是远程服务器上的数据。这就是`OPENROWSET`函数...
此外,实验还涵盖了修改表数据,如添加、修改、删除记录,这些可以通过`INSERT INTO`、`UPDATE`和`DELETE FROM`语句实现,但具体内容未给出示例。 整个实验旨在让学习者深入理解SQL Server 2005的数据库管理和T-SQL...
当目标表已存在时,可以使用`INSERT INTO SELECT`语句将源数据库表的数据复制到目标数据库表中。例如: ```sql INSERT INTO 目的数据库..表 SELECT * FROM 源数据库..表 ``` 这会将源表的所有列和行插入到目标...
如果需要将远程服务器的数据导入到本地服务器,可以使用以下语句: **示例代码**: ```sql -- 将远程服务器的数据导入到本地表 SELECT * INTO 表名 FROM ITSV.数据库名.dbo.表名; ``` #### 删除链接服务器 当不再...
总结来说,不同数据库间复制表数据的方法包括直接的SQL语句操作(如`INSERT INTO SELECT`和`SELECT INTO`),使用`OPENROWSET`,创建和使用链接服务器,以及利用备份和恢复策略。选择哪种方法取决于具体的需求,如...
2. 执行SQL命令:使用SqlCommand类,创建INSERT INTO语句,将Excel数据逐行插入到数据库表。 3. 错误处理和资源释放:确保在操作完成后关闭连接,避免资源泄露。 在导入过程中,为了提高效率,可能采用批处理的方式...
若需将远程服务器上的数据导入到本地服务器,可以使用如下语句: ```sql SELECT * INTO 表 FROM ITSV.数据库名.dbo.表名 ``` 当不再需要链接服务器时,可以通过`sp_dropserver`系统存储过程来删除它: ```sql ...
根据给定文件的信息,本文将详细解析如何在不同的服务器之间同步数据库数据,主要涉及的关键步骤包括:创建数据库链接(DBLink)、使用同义词访问远程表、构建存储过程实现数据同步以及设置定时任务来定期执行数据...
在信息技术领域,数据库管理是一项核心任务,而将数据从不同的来源导入数据库是常见的操作之一。Excel作为广泛使用的电子表格工具,其数据处理功能强大,同时也常被用作临时存储和整理数据的平台。在某些情况下,...
在使用SQL语句迁移数据时,可以通过SELECT...INTO语句将数据插入到新表中,或者使用INSERT INTO语句将数据插入到已存在的表中。需要注意的是,如果要远程连接服务器,网络传输的性能要求较高。 在数据迁移的具体...