zoukankan      html  css  js  c++  java
  • 在T-SQL中访问远程数据库(openrowset、opendatasource、openquery)

     1.  启用Ad Hoc Distributed Queries

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

      SQL Server 阻止了对组件 'Ad Hoc Distributed Queries' 的 STATEMENT'OpenRowset/OpenDatasource'的访问,因为此组件已作为此服务器安全配置的一部分而被关闭。系统管理员可以通过使用sp_configure 启用 'Ad Hoc Distributed Queries'。有关启用 'Ad Hoc Distributed Queries' 的详细信息,请参阅 SQL Server 联机丛书中的 "外围应用配置器"。
    具体启用方法如下:

    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. 示例:

    
    
    --查看当前链接情况 
    select * from sys.servers
    --使用 sp_helpserver 来显示可用的服务器 
    exec sp_helpserver
    
    
    --创建链接服务器 
    --使用sp_addlinkedserver来增加链接 exec sp_addlinkedserver
    @server = 'ITSV',--被访问的服务器别名
    @srvproduct = '',
    @provinder = 'SQLOLEDB',
    @datasrc = '远程服务器名或ip地址 ' --要访问的服务器
    --使用sp_addlinkedsrvlogin 来增加用户登录链接 exec sp_addlinkedsrvlogin
    'ITSV', --被访问的服务器别名,要与上面的一致
    'false',
    null,
    '用户名',
    '密码' --要连接的服务器对应的用户名和密码

    --示例:
    exec sp_addlinkedserver 'ITSV', '', 'SQLOLEDB', '远程服务器名或ip地址 ' exec sp_addlinkedsrvlogin 'ITSV', 'false',null, '用户名', '密码' --要连接的服务器对应的用户名和密码
    --以后不再使用时删除链接服务器
    exec sp_dropserver 'ITSV','droplogins'

    -- 删除已经存在的某个链接
    exec sp_droplinkedsrvlogin 'ITSV',Null
    exec sp_dropserver 'ITSV' --服务器别名

    --查询示例 select * from ITSV.数据库名.dbo.表名 --导入示例 select * intofrom ITSV.数据库名.dbo.表名
    --连接远程/局域网数据(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

    --2、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.  范例:

    Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->--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种:

    1)openrowset 最好,简单而且支持在连接时制定查询语句,使用灵活

    2)openquery 其次,因查询前要先用exec sp_addlinkedserver和exec sp_addlinkedsrvlogin建立服务器和服务器连接稍显麻烦

    3)opendatasource 最后,无法在连接时指定查询

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

    参考博文

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

  • 相关阅读:
    Benelux Algorithm Programming Contest 2016 Preliminary K. Translators’ Dinner(思路)
    Benelux Algorithm Programming Contest 2016 Preliminary Target Practice
    Benelux Algorithm Programming Contest 2016 Preliminary I. Rock Band
    Benelux Algorithm Programming Contest 2016 Preliminary A. Block Game
    ICPC Northeastern European Regional Contest 2019 Apprentice Learning Trajectory
    ICPC Northeastern European Regional Contest 2019 Key Storage
    2018 ACM ICPC Asia Regional
    2018 ACM ICPC Asia Regional
    Mybatis入库出现异常后,如何捕捉异常
    优雅停止 SpringBoot 服务,拒绝 kill -9 暴力停止
  • 原文地址:https://www.cnblogs.com/SunXiaoLin/p/3326606.html
Copyright © 2011-2022 走看看