SQLServer跨库查询--分布式查询

Posted IT足迹

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQLServer跨库查询--分布式查询相关的知识,希望对你有一定的参考价值。

--用openrowset连接远程SQL或插入数据 

--如果只是临时访问,可以直接用openrowset

--查询示例

select * from openrowset(SQLOLEDB

,sql服务器名;用户名;密码

,数据库名.dbo.表名)





--导入示例

select * intofrom openrowset(SQLOLEDB

,sql服务器名;用户名;密码

,数据库名.dbo.表名)



--创建链接服务器

exec sp_addlinkedserver  srv_lnk,‘‘,SQLOLEDB,远程服务器名或ip地址

exec sp_addlinkedsrvlogin srv_lnk,false,null,用户名,密码

go



--查询示例

select * from srv_lnk.数据库名.dbo.表名



--导入示例

select * intofrom srv_lnk.数据库名.dbo.表名



--以后不再使用时删除链接服务器

exec sp_dropserver srv_lnk,droplogins

go

--下面的示例访问来自某个表的数据,该表在 SQL Server 的另一个实例中。

SELECT *FROM OPENDATASOURCE(SQLOLEDB,Data Source=ServerName;User ID=MyUID;Password=MyPass).Northwind.dbo.Categories

--下面是个查询的示例,它通过用于 Jet 的 OLE DB 提供程序查询 Excel 电子表格。

SELECT *FROM OpenDataSource( Microsoft.Jet.OLEDB.4.0,Data Source="c:Financeaccount.xls";User ID=Admin;Password=;Extended properties=Excel 5.0)...xactions
例如:

SELECT *

FROM OPENQUERY(Far_MDB, SELECT * FROM MDB_Member) 

这就是从我的链接服务器当中去查询MDB_Member表的数据

备注:

1、关于链接服务器的详细情况请参阅联机丛书中的sp_addlinkedserver、 sp_addlinkedsrvlogin、sp_addserver、sp_dropserver、sp_serveroption、sp_linkedservers等系统级存储过程。

2、关于此链接服务器的创建及其使用在不同环境下(全部内网服务器、一内网一公网服务器、全公网服务器)测试,均告通过。

3、有时候在存储过程中访问链接服务器的时候可能会碰到如下的提示,必须要对ANSI warning 和ANSI nulls进行设置,这时候按照如下的方法进行设置:

设置本地数据库的属性-->连接-->选上ANSI warning 和 ANSI nulls

如何用sql语句进行跨库查询

在机器B上的数据库database2中创建一个临时表#tmp, 

内容就是机器A上的数据库database1里面的Table1。 

如何用sql语句完成?(不借用dts等)

SQL code --创建链接服务器

exec sp_addlinkedserver  ITSV,‘‘,SQLOLEDB,远程服务器名或ip地址

exec sp_addlinkedsrvlogin ITSV,false,null,用户名,密码

--查询示例

select * from ITSV.数据库名.dbo.表名

--导入示例

select * intofrom ITSV.数据库名.dbo.表名

--以后不再使用时删除链接服务器

exec sp_dropserver ITSV,droplogins

--连接远程/局域网数据(openrowset/openquery/opendatasource)

--1、openrowset

--查询示例

select * from openrowset(SQLOLEDB,sql服务器名;用户名;密码,数据库名.dbo.表名)

--生成本地表

select * intofrom 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 本地表

用   链接服务器 

OPENROWSET 

OPENDATASOURCE 

都可以

链接服务器.database1.dbo.table1

链接服务器.database1.dbo.table1

SQL code 

select * into #

from openrowset(sqloledb,ip;sa;‘‘,select * from pubs.dbo.jobs)

如果只是偶尔使用   就用opendatasource/openrowset   固定的频繁使用建linked   server

 

以上是关于SQLServer跨库查询--分布式查询的主要内容,如果未能解决你的问题,请参考以下文章

sql server 跨库查询

sql 跨库查询的问题

Oracle&SQLServer中实现跨库查询

跨库查询报错

SQL 跨库查询

Oracle数据库怎样跨库查询?