標籤:ole db varchar soft 方法 set 需要 環境 window arch
//執行遠端資料庫表查詢select * from openrowset( ‘SQLOLEDB‘, ‘192.168.5.547‘; ‘sa‘; ‘密碼‘,[資料庫名稱].[dbo].[表名])
出現異常:
訊息 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‘,1reconfigureexec sp_configure ‘Ad Hoc Distributed Queries‘,1reconfigure//關閉Ad Hoc Distributed Queries:exec sp_configure ‘Ad Hoc Distributed Queries‘,0reconfigureexec sp_configure ‘show advanced options‘,0reconfigure
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
[sql異常]SQL Server 阻止了對組件 'Ad Hoc Distributed Queries' 的