简明扼要介绍Oracle Provider

数据库 Oracle
这里介绍我使用Oracle Provider for OLE DB建立了一个新的连结服务器,名称定为orclprvdr。并尝试对该连结服务器执行INSERT指令,这个指令是可以被成功执行的。

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数据库
责任编辑:佚名 来源: 博客园
相关推荐

2009-11-13 08:59:30

2009-12-02 11:22:14

Visual Stud

2009-12-03 18:29:11

2009-11-18 16:43:59

2022-12-20 08:29:59

lambdaJava8

2024-04-01 07:57:11

Lambda代码表达式

2016-03-02 15:09:57

Java虚拟机体系结构

2011-01-06 14:22:50

2015-09-01 14:00:36

云数据中心云转型

2009-07-21 10:40:36

ASP.NET Pro

2009-03-06 16:11:49

RHEL5SendmailDovecot

2010-05-25 16:39:56

SVN中使用Git

2010-05-22 10:38:15

Symbian开发

2010-09-10 15:36:29

CSS缩写

2010-05-27 10:53:54

SVN目录结构

2010-04-20 15:47:31

面试

2020-06-23 14:35:09

等保合规网络安全网络威胁

2021-09-07 09:53:45

鸿蒙HarmonyOS应用

2009-12-30 08:52:17

Ubuntu Tora

2009-11-30 11:33:50

sendmail服务器
点赞
收藏

51CTO技术栈公众号