zl程序教程

您现在的位置是:首页 >  后端

当前栏目

SQL Server 如何跨服务器复制表中数据

server服务器SQL数据 如何 复制 表中
2023-09-14 08:59:47 时间

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

当表目标表存在时:

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.数据表名


[ SQL Server ] 计算N个月前,N个月后的方法 #1. 计算N个月前的日期 #2. 计算N个月后的日期 #3. 月末最后一天的情况(计算从日数多的月到日数较少的月) #4. 月末最后一天的情况(计算从日数少的月到日数较多的月)
【SQL Server】数据库开发指南(三)面向数据分析的 T-SQL 编程技巧与实践 T-SQL 指的是 Transact-SQL,是一种针对 Microsoft SQL Server 数据库系统的 SQL 方言。T-SQL 扩展了标准 SQL 语言,提供了更多的功能和特性,包括事务处理、错误处理、游标处理、动态 SQL、存储过程、触发器、用户定义函数等等。