不同服务器数据库之间的数据操作 mysql_SQL不同服务器数据库之间的数据操作整理(完整版)...

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

-- Author : htl258(Tony)

-- Date : 2010-06-25 22:23:18

-- Version: Microsoft SQL Server 2008 (RTM) - 10.0.1600.22 (Intel X86)

-- Jul 9 2008 14:43:34

-- Copyright (c) 1988-2008 Microsoft Corporation

-- Developer Edition on Windows NT 5.1 (Build 2600: Service Pack 2)

-- Blog : http://blog.csdn.net/htl258(转载保留此信息)

-- Subject: SQL不同服务器数据库之间数据操作整理

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

--1. 创建链接服务器

--1.1 创建一个链接名

EXEC sp_addlinkedserver 'LinkName','','SQLOLEDB','远程服务器名或ip地址' --有自定义实例名还要加上"/实例名"

/*例如:EXEC sp_addlinkedserver 'TonyLink','','SQLOLEDB','192.168.58.208' */

--1.2 创建登录信息(或叫创建链接服务器登录名映射)(只需选择一种方式)

--1.2.1 以windows认证的方式登录

EXEC sp_addlinkedsrvlogin 'LinkName' --或EXEC sp_addlinkedsrvlogin 'LinkName','true'

/*例如:EXEC sp_addlinkedsrvlogin 'TonyLink' */

--1.2.2 以SQL认证的方式登录

EXEC sp_addlinkedsrvlogin 'LinkName','false',NULL,'用户名','密码'

/*例如:EXEC sp_addlinkedsrvlogin 'TonyLink','false',null,'sa','123' */

--2. 链接服务器相关数据操作

--2.1 查询示例

SELECT * FROM LinkName.数据库名.架构名.表名

/*例如:SELECT * FROM TonyLink.Mydb.dbo.tb */

--2.2 导入示例

SELECT * INTO 表名 FROM LinkName.数据库名.架构名.表名

/*例如:SELECT * INTO Newtb FROM TonyLink.Mydb.dbo.tb */

--2.3 更新示例

UPDATE LinkName.数据库名.架构名.表名 SET 字段='值' WHERE 字段='条件'

/*例如:UPDATE TonyLink.Mydb.dbo.tb SET Persons='g' WHERE Persons='a' */

--2.4 删除示例

DELETE LinkName.数据库名.架构名.表名 WHERE 字段名='条件'

/*例如:DELETE TonyLink.Mydb.dbo.tb WHERE Persons='g' */

--3. 通过行集函数(OPENQUERY/OPENROWSET/OPENDATASOURCE)操作方法

--3.1 OPENQUERY 方法(需要借助刚创建的链接服务器):

--3.1.1 查询示例

SELECT * FROM OPENQUERY(LinkName,'SELECT * FROM 数据库名.架构名.表名')

/* 例如:SELECT * FROM OPENQUERY(TonyLink,'SELECT * FROM Mydb.dbo.tb') */

--3.1.2 导入示例

--3.1.2.1 导入所有列

INSERT OPENQUERY(LinkName, 'SELECT * FROM 数据库名.架构名.表名') SELECT * FROM 本地表

/* 例如:INSERT OPENQUERY(TonyLink,'SELECT * FROM Mydb.dbo.tb') SELECT * FROM tb */

--3.1.2.2 导入指定列

INSERT OPENQUERY(LinkName, 'SELECT * FROM 数据库名.架构名.表名') (列,列...)

SELECT 列,列... FROM 本地表

/* 例如:INSERT OPENQUERY(TonyLink,'SELECT * FROM Mydb.dbo.tb')(RANGE,LEVEL,Persons)

SELECT RANGE,LEVEL,Persons FROM tb

*/

--3.1.3 更新示例

UPDATE OPENQUERY(LinkName, 'SELECT * FROM 数据库名.架构名.表名') SET 字段='值' WHERE 字段='条件'

/*例如:UPDATE OPENQUERY(TonyLink, 'SELECT * FROM Mydb.dbo.tb') SET Persons='g' WHERE Persons='a' */

--3.1.4 删除示例

DELETE OPENQUERY(LinkName, 'SELECT * FROM 数据库名.架构名.表名') WHERE 字段名='条件'

/*例如:DELETE OPENQUERY(TonyLink, 'SELECT * FROM Mydb.dbo.tb') WHERE Persons='g' */

--3.2 OPENROWSET方法(不需要用到创建好的链接名。如果连接的实例名不是默认的,需要在"sql服务器名或IP地址"后加上"/实例名")

--3.2.1 查询示例

--3.2.1.1 Windows认证方式查询(以下方法之一即可)

SELECT * FROM OPENROWSET('SQLOLEDB', 'server=sql服务器名或IP地址;Trusted_Connection=yes',数据库名.架构名.表名)

SELECT * FROM OPENROWSET('SQLNCLI', 'server=sql服务器名或IP地址;Trusted_Connection=yes',数据库名.架构名.表名)

SELECT * FROM OPENROWSET('SQLOLEDB', 'server=sql服务器名或IP地址;Trusted_Connection=yes','SELECT * FROM 数据库名.架构名.表名')

SELECT * FROM OPENROWSET('SQLNCLI', 'server=sql服务器名或IP地址;Trusted_Connection=yes','SELECT * FROM 数据库名.架构名.表名')

/* 例如:SELECT * FROM OPENROWSET('SQLOLEDB','Server=192.168.58.208;Trusted_Connection=yes',Mydb.dbo.tb)

或:SELECT * FROM OPENROWSET('SQLNCLI','Server=192.168.58.208;Trusted_Connection=yes',Mydb.dbo.tb)

或:SELECT * FROM OPENROWSET('SQLOLEDB','Server=192.168.58.208;Trusted_Connection=yes','SELECT * FROM Mydb.dbo.tb')

或:SELECT * FROM OPENROWSET('SQLNCLI','Server=192.168.58.208;Trusted_Connection=yes','SELECT * FROM Mydb.dbo.tb')

*/

--3.2.1.2 SQL认证方式查询(以下方法之一即可)

SELECT * FROM OPENROWSET('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码',数据库名.架构名.表名)

SELECT * FROM OPENROWSET('SQLNCLI', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码',数据库名.架构名.表名)

SELECT * FROM OPENROWSET('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码','SELECT * FROM 数据库名.架构名.表名')

SELECT * FROM OPENROWSET('SQLNCLI', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码','SELECT * FROM 数据库名.架构名.表名')

SELECT * FROM OPENROWSET('SQLOLEDB', 'sql服务器名';'用户名'; '密码',数据库名.架构名.表名)

SELECT * FROM OPENROWSET('SQLNCLI', 'sql服务器名';'用户名'; '密码',数据库名.架构名.表名)

SELECT * FROM OPENROWSET('SQLOLEDB', 'sql服务器名';'用户名'; '密码','SELECT * FROM 数据库名.架构名.表名')

SELECT * FROM OPENROWSET('SQLNCLI', 'sql服务器名';'用户名'; '密码','SELECT * FROM 数据库名.架构名.表名')

/* 例如:SELECT * FROM OPENROWSET('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123',mydb.dbo.tb)

或:SELECT * FROM OPENROWSET('SQLNCLI','server=192.168.58.208;uid=sa;pwd=123',mydb.dbo.tb)

或:SELECT * FROM OPENROWSET('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123','SELECT * FROM Mydb.dbo.tb')

或:SELECT * FROM OPENROWSET('SQLNCLI','server=192.168.58.208;uid=sa;pwd=123','SELECT * FROM Mydb.dbo.tb')

或:SELECT * FROM OPENROWSET('SQLOLEDB','192.168.58.208';'sa';'123',mydb.dbo.tb)

或:SELECT * FROM OPENROWSET('SQLNCLI','192.168.58.208';'sa';'123',mydb.dbo.tb)

或:SELECT * FROM OPENROWSET('SQLOLEDB','192.168.58.208';'sa';'123','SELECT * FROM Mydb.dbo.tb')

或:SELECT * FROM OPENROWSET('SQLNCLI','192.168.58.208';'sa';'123','SELECT * FROM Mydb.dbo.tb')

*/

--3.2.2 导入示例

--3.2.2.1 导入所有列

INSERT OPENROWSET('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码',数据库名.架构名.表名)

SELECT * FROM 本地表

/* 例如:INSERT OPENROWSET('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123',mydb.dbo.tb)

SELECT * FROM tb

*/

--3.2.2.2 导入指定列

INSERT OPENROWSET('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码',数据库名.架构名.表名)(列,列...)

SELECT 列,列... FROM 本地表

/* 例如:INSERT OPENROWSET('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123',mydb.dbo.tb)(RANGE,LEVEL,Persons)

SELECT RANGE,LEVEL,Persons FROM tb

*/

--注:更多替代方法参考.2.1查询示例,只需替换行集函数(OPENROWSET)内的内容即可。

--3.2.3 更新示例

UPDATE OPENROWSET('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码',数据库名.架构名.表名)

SET 字段='值'

WHERE 字段='条件'

/*例如:UPDATE OPENROWSET('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123',mydb.dbo.tb)

SET Persons='g'

WHERE Persons='a'

*/

--注:更多替代方法参考.2.1查询示例,只需替换行集函数(OPENROWSET)内的内容即可。

--3.2.4 删除示例

DELETE OPENROWSET('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码',数据库名.架构名.表名)

WHERE 字段名='条件'

/*例如:DELETE OPENROWSET('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123',mydb.dbo.tb)

WHERE Persons='g'

*/

--注:更多替代方法参考.2.1查询示例,只需替换行集函数(OPENROWSET)内的内容即可。

--3.3 OPENDATASOURCE方法(不需要用到创建好的链接名。如果连接的实例名不是默认的,需要在"sql服务器名或IP地址"后加上"/实例名")

--3.3.1 查询示例

--3.3.1.1 Windows认证方式查询(以下方法之一即可)

SELECT * FROM OPENDATASOURCE('SQLOLEDB', 'server=sql服务器名或IP地址;Trusted_Connection=yes').数据库名.架构名.表名

SELECT * FROM OPENDATASOURCE('SQLNCLI', 'server=sql服务器名或IP地址;Trusted_Connection=yes').数据库名.架构名.表名

/* 例如:SELECT * FROM OPENDATASOURCE('SQLOLEDB','Server=192.168.58.208;Trusted_Connection=yes').Mydb.dbo.tb

或:SELECT * FROM OPENDATASOURCE('SQLNCLI','Server=192.168.58.208;Trusted_Connection=yes').Mydb.dbo.tb

*/

--3.3.1.2 SQL认证方式查询(以下方法之一即可)

SELECT * FROM OPENDATASOURCE('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码').数据库名.架构名.表名

SELECT * FROM OPENDATASOURCE('SQLNCLI', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码').数据库名.架构名.表名

SELECT * FROM OPENDATASOURCE('SQLOLEDB', 'Data Source=sql服务器名或IP地址;uid=用户名;pwd=密码').数据库名.架构名.表名

SELECT * FROM OPENDATASOURCE('SQLNCLI', 'Data Source=sql服务器名或IP地址;uid=用户名;pwd=密码').数据库名.架构名.表名

/* 例如:SELECT * FROM OPENDATASOURCE('SQLOLEDB','Server=192.168.58.208;uid=sa;pwd=123').mydb.dbo.tb

或:SELECT * FROM OPENDATASOURCE('SQLNCLI','Server=192.168.58.208;uid=sa;pwd=123').mydb.dbo.tb

或:SELECT * FROM OPENDATASOURCE('SQLOLEDB','Data Source=192.168.58.208;uid=sa;pwd=123').mydb.dbo.tb

或:SELECT * FROM OPENDATASOURCE('SQLNCLI','Data source=192.168.58.208;uid=sa;pwd=123').mydb.dbo.tb

*/

--3.3.2 导入示例

--3.3.2.1 导入所有列

INSERT OPENDATASOURCE('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码').数据库名.架构名.表名

SELECT * FROM 本地表

/* 例如:INSERT OPENDATASOURCE('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123').mydb.dbo.tb

SELECT * FROM tb

*/

--3.3.2.2 导入指定列

INSERT OPENDATASOURCE('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码').数据库名.架构名.表名(列,列...)

SELECT 列,列... FROM 本地表

/* 例如:INSERT OPENDATASOURCE('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123').mydb.dbo.tb(RANGE,LEVEL,Persons)

SELECT RANGE,LEVEL,Persons FROM tb

*/

--注:更多替代方法参考.3.1查询示例,只需替换行集函数(OPENDATASOURCE)内的内容即可。

--3.3.3 更新示例

UPDATE OPENDATASOURCE('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码').数据库名.架构名.表名

SET 字段='值'

WHERE 字段='条件'

/*例如:UPDATE OPENDATASOURCE('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123').mydb.dbo.tb

SET Persons='g'

WHERE Persons='a'

*/

--注:更多替代方法参考.3.1查询示例,只需替换行集函数(OPENDATASOURCE)内的内容即可。

--3.3.4 删除示例

DELETE OPENDATASOURCE('SQLOLEDB', 'server=sql服务器名或IP地址;uid=用户名;pwd=密码').数据库名.架构名.表名

WHERE 字段名='条件'

/*例如:DELETE OPENDATASOURCE('SQLOLEDB','server=192.168.58.208;uid=sa;pwd=123').mydb.dbo.tb

WHERE Persons='g'

*/

--注:更多替代方法参考.3.1查询示例,只需替换行集函数(OPENDATASOURCE)内的内容即可。

--4. 删除链接服务器方法

--如果以后不再使用时可删除链接信息

--4.1 删除登录信息(或叫删除链接服务器登录名映射)

EXEC sp_droplinkedsrvlogin 'LinkName',NULL

/*例如:EXEC sp_droplinkedsrvlogin 'TonyLink',NULL */

--4.2 删除链接服务器名称

EXEC sp_dropserver 'LinkName','droplogins' --如果指定droplogins,则在删除链接服务器之前要删除登录名映射

/*例如:EXEC sp_dropserver 'TonyLink','droplogins' */

--附:获取Provider Name的方法(EXEC master..xp_enum_oledb_providers)

SELECT CAST([Provider Name] AS VARCHAR(30)) ProviderName,

CAST([Provider Description] AS VARCHAR(60)) ProviderDescription

FROM OPENROWSET(

'SQLOLEDB',

'Server=.;Trusted_Connection=yes',

'SET FMTONLY OFF;

EXEC master..xp_enum_oledb_providers'

)

/*

ProviderName ProviderDescription

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

SQLOLEDB Microsoft OLE DB Provider for SQL Server

DTSPackageDSO Microsoft OLE DB Provider for DTS Packages

SQLReplication.OLEDB SQL Server Replication OLE DB Provider for DTS

MSOLAP Microsoft OLE DB Provider for Analysis Services 10.0

MSDMine Microsoft OLE DB Provider For Data Mining Services

Microsoft.ACE.OLEDB.12.0 Microsoft Office 12.0 Access Database Engine OLE DB Provider

ADsDSOObject OLE DB Provider for Microsoft Directory Services

SQLNCLI10 SQL Server Native Client 10.0

MSDAIPP.DSO Microsoft OLE DB Provider for Internet Publishing

MSDASQL Microsoft OLE DB Provider for ODBC Drivers

Microsoft.Jet.OLEDB.4.0 Microsoft Jet 4.0 OLE DB Provider

MSDAOSP Microsoft OLE DB Simple Provider

MSDAORA Microsoft OLE DB Provider for Oracle

MSIDXS Microsoft OLE DB Provider for Indexing Service

(14 行受影响)

*/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值