概述用openrowset连接远程SQL或插入数据 --如果只是临时访问,可以直接用openrowset --
查询示例 select * from openrowset('SQLOLEDB' ,'sql服务器名';'用户名';'密码' ,数据库名.dbo.表名) --导入示例 select * into 表 from openrowset('SQLOLEDB' ,'sql服务器名';'用户名';'密码 用openrowset连接远程sql或插入数据 --如果只是临时访问,可以直接用openrowset --查询示例 select * from openrowset('sqlolEDB','sql服务器名';'用户名';'密码',数据库名.dbo.表名) --导入示例 select * into 表 from openrowset('sqlolEDB',数据库名.dbo.表名) --创建链接服务器 exec sp_addlinkedserver 'srv_lnk','','sqlolEDB','远程服务器名或ip地址' exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码' go --查询示例 select * from srv_lnk.数据库名.dbo.表名 --导入示例 select * into 表 from 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','远程服务器名或ip地址' exec sp_addlinkedsrvlogin 'ITSV','密码' --查询示例 select * from ITSV.数据库名.dbo.表名 --导入示例 select * into 表 from ITSV.数据库名.dbo.表名 --以后不再使用时删除链接服务器 exec sp_dropserver 'ITSV','droplogins' --连接远程/局域网数据(openrowset/openquery/opendatasource) --1、openrowset --查询示例 select * from openrowset('sqlolEDB',数据库名.dbo.表名) --生成本地表 select * into 表 from openrowset('sqlolEDB',数据库名.dbo.表名) --把本地表导入远程表 insert openrowset('sqlolEDB',数据库名.dbo.表名) select *from 本地表 --更新本地表 update b set b.列A=a.列A from openrowset('sqlolEDB',数据库名.dbo.表名)as a inner join 本地表 b on a.column1=b.column1 --openquery用法需要创建一个连接 --首先创建一个连接创建链接服务器 exec sp_addlinkedserver 'ITSV','远程服务器名或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跨库查询--分布式查询全部内容,希望文章能够帮你解决SQLServer跨库查询--分布式查询所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
评论列表(0条)