简明扼要介绍OracleProvider

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。

当前题目:简明扼要介绍OracleProvider
文章链接:http://www.shufengxianlan.com/qtweb/news32/33832.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联