[sql異常]SQL Server 阻止了對組件 'Ad Hoc Distributed Queries' 的


//執行遠程數據庫表查詢

SELECT * FROM OPENDATASOURCE('SQLOLEDB',

                               'Data Source=數據庫地址;User ID=sa;password=sa'

                               ).northwind.dbo.title

 

出現異常:

 

 

消息 15281,級別 16,狀態 1,第 1 行
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

 

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

 

 

sp_addlinkedserver 
創建一個鏈接的服務器,使其允許對分布式的、針對 OLE DB 數據源的異類查詢進行訪問。在使用 sp_addlinkedserver 創建鏈接的服務器之后,此服務器就可以執行分布式查詢。如果鏈接服務器定義為 Microsoft® SQL Server™,則可執行遠程存儲過程。 

語法 
sp_addlinkedserver [ @server = ] 'server' 
[ , [ @srvproduct = ] 'product_name' ] 
[ , [ @provider = ] 'provider_name' ] 
[ , [ @datasrc = ] 'data_source' ] 
[ , [ @location = ] 'location' ] 
[ , [ @provstr = ] 'provider_string' ] 
[ , [ @catalog = ] 'catalog' ] 
語法 
sp_addlinkedsrvlogin [ @rmtsrvname = ] 'rmtsrvname' 
[ , [ @useself = ] 'useself' ] 
[ , [ @locallogin = ] 'locallogin' ] 
[ , [ @rmtuser = ] 'rmtuser' ] 
[ , [ @rmtpassword = ] 'rmtpassword' ] 


[@useself =] 'useself' 

決定用於連接到遠程服務器的登錄名稱。useself 的數據類型為 varchar(8),默認設置為 TRUE。true 值指定 SQL Server 驗證的登錄使用其自己的憑據以連接到 rmtsrvname,而忽略 rmtuser 和 rmtpassword 參數。false 值指定 rmtuser 和 rmtpassword 參數用來連接到特定 locallogin 的 rmtsrvname。如果 rmtuser 和 rmtpassword 也設置為 NULL,則連接鏈接服務器不需使用任何登錄或密碼。對於 Windows NT 身份驗證登錄而言,useself 為 true 則無效,除非 Microsoft Windows NT® 環境支持安全帳戶委托,並且,提供程序支持 Windows 身份驗證(此時不再需要創建值為 true 的映射,不過創建仍然有效)。 

[ @locallogin =] 'locallogin' 

本地服務器上的登錄。locallogin 的數據類型為 sysname,默認設置為 NULL。NULL 值指定此條目將應用於所有連接到 rmtsrvname 的本地登錄。如果值不為 NULL,則 locallogin 可以是一個 SQL Server 登錄或 Windows NT 用戶。必須授予 Windows NT 用戶直接訪問 SQL Server 或通過其作為已授予訪問權限的組的成員來訪問 SQL Server 的權限。   
不同服務器數據庫之間的數據操作
--創建鏈接服務器 
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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM