//執行遠程數據庫表查詢 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 聯機叢書中的 "外圍應用配置器"。
利用沙盒模式失敗時須要用到,解決方法:
sql
//啓用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) --一、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 --三、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