简明扼要介绍Oracle Provider

树叶云

Oracle有很多值得学习的地方,这里我们主要介绍Oracle provider,包括介绍Oracle table等方面。从SQL Server将资料新增至Oracle table时,不需要包含INTO关键词。Microsoft和Oracle的OLE DB providers在Oracle Server上执行INSERT 指令时都会自动加上INTO关键词。

我使用Oracle Provider for OLE DB建立了一个新的连结服务器,名称定为orclprvdr。并尝试对该连结服务器执行INSERT指令,这个指令是可以被成功执行的。所以您可以发现:在透过连结服务器执行INSERT指令时,Oracle provider提供较多的优点!然而,如果 table内某字段有设定DEFAULT约束条件,则使用Oracle provider会无法执行INSERT指令加入数据。不同的是,如果您使用 Microsoft的provider,只要传递实际的字段值,而非使用DEAULT关键词,则INSERT指令就可以执行。

这个查询并没有特别设定dname,loc字段为NULL值,但仍旧可以执行。如果是使用Microsoft OLE DB provider for Oracle就必须给定其字段值。UPDATE指令使用在可允许NULL值存放的字段上就不会有问题,这点和INSERT指令不同。如果是对Oracle执行UPDATE指令,不想修改的字段可以不用列出。
 
如果您需要针对SQL Server与Oracle的table进行联集(join)查询,就必须要有连结服务器才能执行这类的异质性查询。为了建立下面的范例程序,我使用了资料转换服务(Data Transformation Services,DTS) 将Northwind数据库内的Orders table复制一份到Oracle数据库内的SCOTT schema之下,并且将预设的目的地从 “SCOTT”.”Orders” 改成 “SCOTT”.”ORDERS”。我在这里使用大写子母的原因是为了避免在Oracle工具内使用到该table时还要加上双引号。虽然Oracle数据库有支持大小写混合式数据库对象名称,但是全部使用大写来命名对象名称的话,对于Oracle数据库管理以及程序开发将会变得较为容易!

下列范例将针对Northwind 数据库的Employees table 与SCOTT的Order table

进行联集查询:

  1. SELECT lastname FROM employees e  
  2. INNER JOIN oradb..SCOTT.ORDERS o  
  3. ON e.employeeid = o.employeeid  
  4. WHERE o.orderid = 10248 

如果您所执行的这类查询指令必须置于一个交易(transaction)内,则SQL Server所在的服务器必须激活交易协调器(Microsoft Distributed Transaction Coordinator (MS DTC)这项服务。

以下提供数种使用连结服务器进行查询的方式。例如SQL Server的OPENQUERY 系统函数会将查询指令整个从SQL Server传递至Oracle:

  1. SELECT *  
  2. FROM OPENQUERY (oradb,' SELECT * FROM dept  
  3. WHERE deptno = 10' ) 

 使用OPENQUERY并不会在查阅Oracle系统资料(metadata)时造成额外影响。有了OPENQUERY这个函数,所有查询动作都会发生在 Oracle连结服务器上,可避免查询系统资料所可能增加的系统负担。使用OPENQUERY来执行连结服务器的查询指令是一项较佳的选择,但是您无法在异质性的查询指令中使用!

至于OPENROWSET 则是一种不需要事先设定连结服务器就可以执行的一种转嫁查询(pass-through query)。除了您必须指定联机时需要的所有资料作为输入参数之外,其功能与OPENQUERY函数类似:

  1. SELECT *  
  2. FROM OPENROWSET (' MSDAORA','Ora817'; 'SCOTT';'TIGER',  
  3. ' SELECT * FROM dept  
  4. WHERE deptno = 10' ) 

本文所提到的连结服务器只用来执行查询指令,但是您也可以透过连结服务器执行预储程序。以上介绍Oracle provider。

【编辑推荐】

  1. 简讨Oracle pctused参数
  2. 巧学Oracle数据库联机
  3. Provider for Oracle简介
  4. 探讨Oracle Server客户端组态
  5. 概括SQL Server实时查询Oracle数据库

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/233023.html<

(0)
运维的头像运维
上一篇2025-04-20 10:42
下一篇 2025-04-20 10:43

相关推荐

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注