SQL SERVER数据库 LINK ORACLE数据库 如何实现在SQL SERVER查询分析器中对ORACLE查询
2011-07-11 14:21
501 查看
本文采用的是Sql Server 中的OpenQuery函数来实现对ORACLE数据库交互
OPENQUERY ( linked_server ,'query' )
参数
linked_server
表示链接服务器名称的标识符。
' query '
在链接服务器中执行的查询字符串。该字符串的最大长度为 8 KB。
注释
OPENQUERY 不接受其参数的变量。
OPENQUERY 不能用于对链接服务器执行扩展存储过程。但是,通过使用四部分名称,可以在链接服务器上执行扩展存储过程。例如:
EXEC SeattleSales.master.dbo.xp_msver
权限
任何用户都可以执行 OPENQUERY。用于连接到远程服务器的权限是从为链接服务器定义的设置中获取的。
示例
A. 执行 SELECT 传递查询
以下示例将使用“用于 Oracle 的 Microsoft 访问接口”针对 Oracle 数据库创建一个名为 OracleSvr 的链接服务器。然后,该示例针对此链接服务器使用 SELECT 传递查询。
本示例假定已经创建了一个名为 ORCLDB 的 Oracle 数据库别名
EXEC sp_addlinkedserver 'OracleSvr', 'Oracle 7.3', 'MSDAORA', 'ORCLDB' GO
SELECT * FROMOPENQUERY(OracleSvr, 'SELECT name, id FROM joe.titles') GO
B. 执行 UPDATE 传递查询
以下示例针对示例 A 中创建的链接服务器使用 UPDATE 传递查询。
UPDATE OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles WHERE id = 101') SET name = 'ADifferentName';
C. 执行 INSERT 传递查询
以下示例针对示例 A 中创建的链接服务器使用 INSERT 传递查询。
INSERT OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles') VALUES ('NewTitle');
D. 执行 DELETE 传递查询
以下示例使用 DELETE 传递查询删除示例 C 中插入的行。
DELETE OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles WHERE name = ''NewTitle''');
OPENQUERY ( linked_server ,'query' )
参数
linked_server
表示链接服务器名称的标识符。
' query '
在链接服务器中执行的查询字符串。该字符串的最大长度为 8 KB。
注释
OPENQUERY 不接受其参数的变量。
OPENQUERY 不能用于对链接服务器执行扩展存储过程。但是,通过使用四部分名称,可以在链接服务器上执行扩展存储过程。例如:
EXEC SeattleSales.master.dbo.xp_msver
权限
任何用户都可以执行 OPENQUERY。用于连接到远程服务器的权限是从为链接服务器定义的设置中获取的。
示例
A. 执行 SELECT 传递查询
以下示例将使用“用于 Oracle 的 Microsoft 访问接口”针对 Oracle 数据库创建一个名为 OracleSvr 的链接服务器。然后,该示例针对此链接服务器使用 SELECT 传递查询。
本示例假定已经创建了一个名为 ORCLDB 的 Oracle 数据库别名
EXEC sp_addlinkedserver 'OracleSvr', 'Oracle 7.3', 'MSDAORA', 'ORCLDB' GO
SELECT * FROMOPENQUERY(OracleSvr, 'SELECT name, id FROM joe.titles') GO
B. 执行 UPDATE 传递查询
以下示例针对示例 A 中创建的链接服务器使用 UPDATE 传递查询。
UPDATE OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles WHERE id = 101') SET name = 'ADifferentName';
C. 执行 INSERT 传递查询
以下示例针对示例 A 中创建的链接服务器使用 INSERT 传递查询。
INSERT OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles') VALUES ('NewTitle');
D. 执行 DELETE 传递查询
以下示例使用 DELETE 传递查询删除示例 C 中插入的行。
DELETE OPENQUERY (OracleSvr, 'SELECT name FROM joe.titles WHERE name = ''NewTitle''');
相关文章推荐
- Oracle, SQL Server, My SQL如何实现数据分页查询语句
- sql server数据库如何建立数据链接到ORACLE数据库,并通过链接查询ORACLE中的表。
- Oracle, SQL Server, My SQL如何实现数据分页查询语句
- 如何用eclipse将数据库oracle数据相连接,实现查询数据库中的信息以及更改添加表中内容
- 浅析如何实现SQL Server高效率跨服务器查询
- 如何在Sql Server 2000中用一条语句实现树的查询
- Oracle和SQL Server实现跨库查询
- 如何实现插入时如果不存在则插入如果存在则更新的操作(分别用oracle、MySQL和SQL Server实现)
- Oracle如何实现跨库查询
- Oracle如何实现跨库查询
- Oracle如何实现跨库查询
- Sql Server 2000,Sql Server 2005以及Oracle下如何实现数据分页
- Oracle如何实现跨库查询
- SAP 如何实现跨系统取数 SAP读取ORACLE或者SQL server数据库
- 如何查询Oracle,Sql Server,MySQL 中的数据库名称、数据表名称、字段名称
- sql server添加oracle查询linkserver
- Oracle如何实现跨数据库查询
- Oracle如何实现跨库查询
- 如何在ORACLE中实现将查询结果存到一个新表中,包括表结构和查询结果?
- Oracle如何实现跨库查询