在T-SQL语句中访问远程数据库(openrowset/opendatasource/openquery)

来源:http://www.cnblogs.com/OpenCoder/archive/2010/03/18/1689321.html

1、启用Ad Hoc Distributed Queries

在使用openrowset/opendatasource前搜先要启用Ad Hoc Distributed Queries服务,因为这个服务不安全所以SqlServer默认是关闭的

启用Ad Hoc Distributed Queries的方法

SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource'

的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用

sp_configure 启用 'Ad Hoc Distributed Queries'。有关启用 'Ad Hoc Distributed Queries' 的详细

信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。
启用Ad Hoc Distributed Queries的方法,执行下面的查询语句就可以了:

exec sp_configure 'show advanced options',1
reconfigure
exec sp_configure 'Ad Hoc Distributed Queries',1
reconfigure
使用完毕后,记得一定要要关闭它,因为这是一个安全隐患,切记执行下面的SQL语句

exec sp_configure 'Ad Hoc Distributed Queries',0
reconfigure
exec sp_configure 'show advanced options',0
reconfigure  

2、使用示例

--创建链接服务器 
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 本地表

3、例子

--openrowset使用OLEDB的一些例子
select * from openrowset('SQLOLEDB','Server=(local);PWD=***;UID=sa;','select * from TB.dbo.school') as t
select * from openrowset('SQLOLEDB','Server=(local);PWD=***;UID=sa;',TB.dbo.school) as t
select * from openrowset('SQLOLEDB','Server=(local);Trusted_Connection=yes;',TB.dbo.school) as t
select * from openrowset('SQLOLEDB','(local)';'sa';'***','select * from TB.dbo.school') as t
select * from openrowset('SQLOLEDB','(local)';'sa';'***',TB.dbo.school) as t
select * from openrowset('SQLOLEDB','(local)';'sa';'***','select school.id as id1,people.id as id2 from TB.dbo.school inner join TB.dbo.people on school.id=people.id') as t--openrowset使用SQLNCLI的一些例子(SQLNCLI在SqlServer2005以上才能使用)
select * from openrowset('SQLNCLI','(local)';'sa';'***','select * from TB.dbo.school') as t
select * from openrowset('SQLNCLI','Server=(local);Trusted_Connection=yes;','select * from TB.dbo.school') as t
select * from openrowset('SQLNCLI','Server=(local);UID=sa;PWD=***;','select * from TB.dbo.school') as t
select * from openrowset('SQLNCLI','Server=(local);UID=sa;PWD=***;',TB.dbo.school) as t
select * from openrowset('SQLNCLI','Server=(local);UID=sa;PWD=***;DataBase=TB','select * from dbo.school') as t--openrowset其他使用
insert openrowset('SQLNCLI','Server=(local);Trusted_Connection=yes;','select name from TB.dbo.school where id=1') values('ghjkl')/*要不要where都一样,插入一行*/
update openrowset('SQLNCLI','Server=(local);Trusted_Connection=yes;','select name from TB.dbo.school where id=1') set name='kkkkkk'
delete from openrowset('SQLNCLI','Server=(local);Trusted_Connection=yes;','select name from TB.dbo.school where id=1')--opendatasource使用SQLNCLI的一些例子
select * from opendatasource('SQLNCLI','Server=(local);UID=sa;PWD=***;').TB.dbo.school as t
select * from opendatasource('SQLNCLI','Server=(local);UID=sa;PWD=***;DataBase=TB').TB.dbo.school as t--opendatasource使用OLEDB的例子
select * from opendatasource('SQLOLEDB','Server=(local);Trusted_Connection=yes;').TB.dbo.school as t--opendatasource其他使用
insert opendatasource('SQLNCLI','Server=(local);Trusted_Connection=yes;').TB.dbo.school(name) values('ghjkl')/*要不要where都一样,插入一行*/
update opendatasource('SQLNCLI','Server=(local);Trusted_Connection=yes;').TB.dbo.school set name='kkkkkk'
delete from opendatasource('SQLNCLI','Server=(local);Trusted_Connection=yes;').TB.dbo.school where id=1--openquery使用OLEDB的一些例子
exec sp_addlinkedserver   'ITSV', '', 'SQLOLEDB','(local)' 
exec sp_addlinkedsrvlogin 'ITSV', 'false',null, 'sa', '***'
select * FROM openquery(ITSV,  'SELECT *  FROM TB.dbo.school ') --openquery使用SQLNCLI的一些例子
exec sp_addlinkedserver   'ITSVA', '', 'SQLNCLI','(local)' 
exec sp_addlinkedsrvlogin 'ITSVA', 'false',null, 'sa', '***'
select * FROM openquery(ITSVA,  'SELECT *  FROM TB.dbo.school ') --openquery其他使用
insert openquery(ITSVA,'select name from TB.dbo.school where id=1') values('ghjkl')/*要不要where都一样,插入一行*/
update openquery(ITSVA,'select name from TB.dbo.school where id=1') set name='kkkkkk'
delete openquery(ITSVA,'select name from TB.dbo.school where id=1')

4、总结

可以看到SqlServer连接多服务器的方式有3种

其中我个人认为openrowset最好,使用简单而且支持在连接时制定查询语句使用很灵活

openquery也不错查询时也可以指定查询语句使用也很灵活,不过查询前要先用exec sp_addlinkedserver和exec sp_addlinkedsrvlogin建立服务器和服务器连接稍显麻烦

opendatasource稍显欠佳,他无法在连接时指定查询使用起来稍显笨拙

另外还可以连接到远程Analysis服务器做MDX查询,再用T-Sql做嵌套查询,可见T-SQL的远程查询非常强大



本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/497735.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

单招湖南工业技术学院计算机难吗,解读湖南三一工业职业技术学院单招考试难吗...

走单招的竞争不会太激烈,因此学生们可以用不高的分数去一个比较好的专科学校。对于成绩不好的学生来说,选择单招的学生上大学的几率比较大。来我们了解一下解读湖南三一工业职业技术学院单招考试难吗什么是高职分类考试招生高职分类考试招生是普通高等教…

2017回顾:哪些领域被过度炒作,哪些领域又需要更多关注?

来源:全球创新论坛概要:不管是虚拟现实、增强现实,还是可穿戴设备,其炒作高峰似乎已经是明日黄花,已经是过去两年的事情,不知为何仍然排在炒作榜高位。不管是虚拟现实、增强现实,还是可穿戴设备…

重庆高职高专计算机排名,重庆十大大专排名(含分数线2021年参考)-重庆最好的全日制专科学校...

选择科目测一测我能上哪些大学选择科目领取你的专属报告>选择省份关闭请选择科目确定v>对于重庆考生来说,重庆专科院校的排名一直都是比较关注的话题。那么,本期圆梦志愿小编就带大家来了解一下“重庆十大大专排名及分数线”以及“重庆最好的大专全日制专科学…

无法初始化链接服务器 (null) 的 OLE DB 访问接口 Microsoft.Jet.OLEDB.4.0 的数据源对象。

SQL Server 与 Excel之间导数据时候执行SQL遇到问题 执行如下SQL语句 select * from openrowset(Microsoft.Jet.OLEDB.4.0,Excel 8.0;HDRYes;IMEX1;Databased:\sysuser.xlsx,[Sheet1$]) 提示错误: 第一步:保证Excel 文件与 SQL Server 数据库服务器在…

2018新年感谢,写在互联网类脑架构研究十年的前夜

概要:明天,是新的一年,也是我们研究互联网类脑架构,发表第一篇文章《互联网大脑进化示意图》正好10年的的日期。2018年1月1日,是新一年的第一天,也是我们研究互联网类脑架构,发表第一篇文章《互…

在SQL Server数据库之间进行数据导入导出

来源:http://kb.cnblogs.com/page/94464/ 在SQL Server数据库之间进行数据导入导出 (1).使用SELECT INTO导出数据 在SQL Server中使用最广泛的就是通过SELECT INTO语句导出数据,SELECT INTO语句同时具备两个功能: 1、根据SELECT后跟的字段…

中档微型计算机配置图,实训1-微机应用现状调研实训报告.docx

文档介绍:实训1微机应用现状调研实训报告实训内容实训要求1.微机硬件组成调研。2.市场主流微处理器信息搜集。3.主流内存信息搜集。4.微机操作系统应用调研。5.微机常用应用软件调研。6.用户对微机性能的关注程度调研。7.微机主要用途调研。通过市场的现场调研或互联…

计算机考研没奖,备战考研本科期间没有什么奖项,考研复试会有影响吗?

原标题:备战考研本科期间没有什么奖项,考研复试会有影响吗?考研复试是考研的最后阶段,因为复试采用的是差额复试,也就是进入复试人员大于拟录取人员。所以,复试还是有很大的竞争的。如何在复试中取得良好的…

HT中特殊字符φ的显示问题

HT中特殊字符φ如下才能正常显示 <text mode"1" size"1" x"1" y"9">名称:</text><text mode"1" size"1" x"6" y"9"><s:property escape"false" escapeXml&q…

2018年人工智能和机器学习路在何方?听听美国公司怎么做

来源&#xff1a;可译网翻译 | 言午二二、Amanda沈概要&#xff1a;与DevOps&#xff08;开发运营&#xff09;不同的是&#xff0c;它涉及到更多的人员和方法&#xff0c;因为新技术正在给商业管理战略带来变革。本文为美国著名数据分析网站DZone分析师Tom Smith与Exaptive的副…

oracle查看锁表进程,杀掉锁表进程

查看锁表进程SQL语句1&#xff1a; select sess.sid, sess.serial#, lo.oracle_username, lo.os_user_name, ao.object_name, lo.locked_mode from v$locked_object lo, dba_objects ao, v$session sess where ao.object_id lo.object_id and lo.session_id sess.sid; 查看锁…

2017 • AI芯片元年

本文转载自公众号&#xff1a;StarryHeavensAbove概要&#xff1a;2017年&#xff0c;AI芯片是半导体产业的亮点&#xff0c;而它受到的关注又远远超出半导体的圈子。2017年&#xff0c;AI芯片是半导体产业的亮点&#xff0c;而它受到的关注又远远超出半导体的圈子。这一年&…

计算机组成原理算术运算实验报告,计算机组成原理算术逻辑运算实验报告

计算机组成原理算术逻辑运算完整实验报告一、实验目的了解运算器的组成结构 掌握运算器的工作原理 掌握简单运算器的数据传输通路验证运算功能发生器74LS181的组合功能二、实验设备TDN&#xff0d;CM教学实验系统一套三、实验原理运算器单元电路图运算器的两个数据输入端由两个…

生产者-消费者 BlockingQueue 运用示例

简单说明&#xff1a; 1、生产者负责将字符串转换成int 数字放入BlockingQueue&#xff0c;失败就停止生产消费线程。 2、消费者从BlockingQueue获得数字&#xff0c;取平方根值&#xff0c;并累积值。如果有负数&#xff0c;失败&#xff01;停止生产消费线程。 3、模拟一个…

河北二本计算机专业排名,河北省最好的二本财经类大学有哪些

河北省最好的二本财经类大学有哪些2020-06-20 17:01:20文/刘思琪河北省是我国高考大省&#xff0c;2019年高考报名人数创近十年新高&#xff0c;报名人数达55.96万人。高考人数的增加会导致竞争更加激烈&#xff0c;那么对于分数不是很高的同学而言选择本省的一些高校是比较不错…

为什么大家都不戳破深度学习的本质?

来源&#xff1a; 36大数据概要&#xff1a;人类正在慢慢接近世界的本质——物质只是承载信息模式的载体。人脑之外的器官都只是保障这一使命的给养舰队。人类正在慢慢接近世界的本质——物质只是承载信息模式的载体。人脑之外的器官都只是保障这一使命的给养舰队。自从去年 Al…

致研究者:2018 AI 研究趋势

来源&#xff1a;网络大数据概要&#xff1a;2017 年是机器学习领域最有成效、最具创意的一年。现在已经有很多博文以及官方报道总结了学界和业界的重大突破。2017 年是机器学习领域最有成效、最具创意的一年。现在已经有很多博文以及官方报道总结了学界和业界的重大突破。本文…

大学计算机导论报告,大学计算机导论论文参考.docx

大学计算机导论论文参考大学计算机导论论文范文一&#xff1a;计算机导论课论文专业&#xff1a;计算机非师专业 姓名&#xff1a;吴闪电 在当今世界&#xff0c;几乎所有专业都与计算机息息相关。所以计算机的发明无疑是20世纪最卓越的成就之一。时至今日&#xff0c;计算计的…

sys_connect_by_path 用法

个人觉得这个函数其实很好用&#xff0c;sys_connect_by_path(字段名, 2个字段之间的连接符号)&#xff0c;注意这里的连接符号不要使用逗号&#xff0c;oracle会报错&#xff0c;如果一定要用&#xff0c;可以使用replace替换一下&#xff0c;方法如下 REPLACE(字段名,原字符,…

css怎样定义div大小,css如何设置div大小

在css中&#xff0c;可以使用width属性和height属性来设置div大小&#xff0c;只需要给div元素设置“width:值”和“height:值”样式即可。width属性定义元素内容区的宽度&#xff0c;height属性定义元素内容区的高度。本教程操作环境&#xff1a;windows7系统、CSS3&&…