`
jiasongmao
  • 浏览: 667058 次
  • 性别: Icon_minigender_1
  • 来自: 石家庄
社区版块
存档分类
最新评论

oracle操作xml笔记一

阅读更多

声明:该文章源于oracle官网 ,经博文只是对其进行了梳理。

 

本文适用于不了解 Oracle 中 XML 实现的 DBA 或开发人员:其中简要概述了 SQL 和 XML 互操作性和如何着手处理存储在 Oracle 10g 第 2 版数据库中的 XML 文档,此外,还介绍了 DBA 和开发人员在数据库中使用 XML 之前应该熟悉的由 Oracle 数据库 10g 第 2 版提供的大量新特性。使用这些 SQL/XML 特性,可以轻松增强您在使用关系数据时获取的技能,以便帮助您使用 XML。

 

什么是 Oracle 的 XML 实现?

Oracle 已经通过数据库的 XML DB 组件实现了 XML,该组件是企业版和标准版的标准特性。通过数据库配置助手 (DBCA) 或者运行一个目录脚本 catqm.sql,可以轻松安装 Oracle XML DB。XML DB 产品提供本文讨论的所有特性。

要验证是否安装了 XML DB,只需运行下面的 SQL:

select comp_name from dba_registry where comp_name like '%XML%';	

COMP_NAME		
Oracle XML Database

 也可以查看 XML DB 模式及其对象来确认是否安装了 Oracle XML DB。

 

SQL 和 XML 协作

SQL/XML 标准已处在开发之中,以便提供一个允许我们从关系查询生成 XML 的机制,并反之使我们能够从 XML 文档提交 SQL 数据。Oracle 数据库 10g 第 2 版中的 Oracle XML DB 实现 SQL 2003 和来自即将推出的 SQL/XML 标准版的特性。Oracle 中这些标准的实现使我们能够以在之前 SQL 标准中不可能的方式查看 XML 文档。

新数据类型。 Oracle9i 数据库第 1 版中引入了一个新数据类型 XMLType,它允许在 SQL 中访问数据库中的 XML 文档,同时允许 XML 开发人员在文档中使用 XML 标准。该数据类型通知数据库该内容是 XML 格式的,并允许我们在 XML 文档上执行查询。使用 XMLType(而非一个关系或 CLOB 实现)在应用程序和存储模型间提供一个分离层。该分离允许数据移到一个不同的存储模型,而不局限于 CLOB 或关系模型。XMLType 可用于创建表、列或视图。它还可用作参数和变量的数据类型。

内置的 XML 方法可以处理文档内容,允许我们创建、提取和索引 XML 数据。索引可以使用 b 树、文本索引和基于函数的索引执行。实际上,与 XPath 合并的 XMLType 数据可用于查看文档。该功能通过 PL/SQL 和 Java API 提供。XMLType 可用在 PL/SQL、使用 JDBC 的 Java 以及 Oracle Data Provider for .Net 中。这个功能强大且相对较新的数据类型将在本文中广泛使用。

存储结构。 Oracle 的 XML 实现为我们提供了以两种不同方式存储数据的灵活性:结构化存储和非结构化存储。XMLType 数据在存储为单个 LOB 列时是非结构化的,在实现为对象集时是结构化的。

它的一个特定示例是 XMLType 表,该表可以使用这两种存储模型之一实现。XMLType 表在使用如下所示的“XMLType store as CLOB”语法实现为 LOB 时是非结构化的:

create table table_name of XMLtype
XMLType store as CLOB; 

让我们重点看一下 XML 数据的结构化存储和非结构化存储并进行更详细的了解。

结构化存储。 将结构化 XML 存储实现为一组对象。这些对象可通过具有可以在表间实现的引用约束的表以关系格式实现。它们也可以使用一个 XMLSchema 实现,以便将一个 XMLType 文档分解为一组对象。

在使用关系表的情况中,可以因此对这些表进行预先设计,或者使用现有表。该文档实际上通过关系表存储为“虚拟”文档,并保留其逻辑结构。该方法可维护文档 对象模型 (DOM) 保真度,但是它不是文档的逐字节物理表示。这可以通过创建一个关于现有关系数据的 XMLType 视图来完成。

结构化存储比非结构化存储具有一些性能优势,选择它可通过表和索引设计提供更多的查询和更新优化。结构化存储上的 XML 操作有助于减少内存和存储,因为没有存储 XML 标记,而且存在更细粒度的数据检索和使用。基于 b 树和基于函数的索引使用得到了增强,而且使用 XPath 重写可在文档的部分上执行适当更新。所有这些都对性能有所帮助,本文稍后将详细讨论。

使用结构化存储也有一些缺点。插入和检索整个文档需要更多开销。此外,灵活性有限,因为只能存储匹配 XMLSchema 的文档 — 但是在某些情况中,这实际上是个优势。文档不存储为逐字节原始表示,而且不保留文档中的数据顺序。但是,这将不会出现数据丢失的情况。

我们通常会将高度结构化的数据看作是 XML,其中数据的每个元素都可以清晰定义。

非结构化存储。 XML 可以使用 CLOB 存储以非结构化方式存储在 Oracle 中,以便 SQL 查询不会知道该数据的结构。该数据可以使用 Oracle 的 XMLType 数据类型存储。

如果想让存储数据匹配文档的准确物理表示,可以选择非结构化数据。此外,如果该数据不经常更新,或者整个文档(而非部分文档)有大量的插入和读取,则将数 据整体放在一处可能更高效。在某些情况中,您需要保持文档的灵活性,而且在这些情况中,XMLType 表或列可能是有用的。

非结构化存储的缺点是,对部分文档的更新通常不如结构化数据那样高效。此外,使用函数从 CLOB 构造 DOM 的 XPath 操作将使用大量的系统资源。非结构化数据的其他问题是,SQL 约束无法实现,而且内存管理也不是如此有效。

我们通常不将非结构化数据作为 XML 数据考虑,并将其中大部分或所有数据只看作是单个 CLOB。

了解了这些存储模型后,现在让我们来看一些命名特性。

 

命名空间中有什么?

这是一个大主题,也是需要了解的较复杂的 XML DB 概念之一。在本文中,我们将介绍一些命名空间概念,以便您了解其要旨所在及其用法。

命名空间用于描述 XML 文档中的一组相关属性或元素。命名空间可用于确保文档构造有完全唯一的名称。XMLSchema 尤其要利用该特性,因为目标命名空间通常与 XMLSchema 的 URI 相同。命名空间示例如下所示。请注意,该命名看起来类似于一个 Internet URL。该命名标准由万维网联盟 (W3C) 建议,但并非必需。该 URI 用于唯一标识数据库中注册的 XMLSchema 的名称,而且无需是文档所处位置的物理 URL。

XMLType 方法和 XML 函数使用命名空间前缀。当 XML 文档没有目标命名空间时,该命名空间前缀将位于 noNameSpace 命名空间中。属性 xsi:noNamespaceSchemaLocation 可用于模式 URI。

如果元素不具备另一个命名空间前缀,默认情况下,在将某个命名空间应用到描述它的元素时,可使用该命名空间。

通常您将看到两个特定的命名空间。它们是 http://www.w3.org/2001/XMLSchema (完整的 XMLSchema 命名空间)和 http://xmlns.oracle.com/xdb (Oracle 提供的 XML DB 命名空间)。第二个命名空间具有写入基础 SQL 函数的函数。一些 XPath 函数也进行重写。例如 ora:contains、ceiling、floor、not、string-length、substring 和 translate。XML DB 使用的属性也属于该命名空间。

定义元素时,我们可以指定该元素的命名空间。在 XML 中,我们可以将它定义为

<elementName xmlns:ab="http.name.com" /> 

如您所见,我们提供了一个 elementName,它是我们将使用的元素(例如,“orders”)。Xmlns 是保留字,它告诉我们这是一个命名空间定义。“ab”部分称为前缀。该前缀是一个绑定到 URL 的简称。在本例中,ab 绑定到‘http.name.com’,而且 ab 可以加为元素名的前缀。

下面我们将创建一个非常小的模式,并声明绑定前缀 xs 到 http://www.w3.org/2001/XMLSchema 以及声明前缀 xdb 到 http://xmlns.oracle.com/xdb 。为了声明该命名空间,我们使用 xmlns 绑定它们。请注意,xs 前缀在本例中用在模式元素名称上。

<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" 
           xmlns:xdb= "http://xmlns.oracle.com/xdb" version="1.0">
<xs:element name="INVOICESCHEMA" xdb:defaultTable="INVOICESCHEMA">
   <xs:complexType>
        <xs:sequence>
             <xs:element name="MailAddressTo">
                   <xs:complexType>
                         <xs:sequence> 
                              <xs:element name="Person" type="xs:string"
<xs:element name="Street" type="xs:string"/>
</xs:sequence>
<xs:attribute name="id" type="xs:string" use="required"/>  
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>

这里我们只是粗略介绍了一下命名空间。

分享到:
评论

相关推荐

    达内corejava+Oracle+JDBC+XML笔记

    "达内corejava+Oracle+JDBC+XML笔记"这份资料涵盖了Java开发的核心部分,对于初学者或者希望巩固基础的开发者来说,是一份宝贵的资源。CoreJava笔记可能包括了类和对象的创建、继承、封装、多态等OOP原则,以及集合...

    oracle培训笔记2

    在"Oracle培训笔记2"中,我们可以看到一系列的课程涵盖了XML基础和多行函数的应用,这些都是Oracle数据库管理和开发中的关键知识点。 XML(可扩展标记语言)在Oracle中的应用非常广泛,特别是在数据交换和存储非...

    oracle ocp老外笔记

    这份"Oracle OCP老外笔记"显然是一份详细的学习资料,被BooBookee平台上的众多学习者所推崇。从提供的压缩包文件名来看,我们可以推测这是一份涵盖了Oracle 9i版本的相关教程。 Oracle 9i是Oracle数据库的一个重要...

    ORACLE笔记笔记_ZCY

    1. **关系数据库模型**:Oracle基于关系数据库模型,使用SQL(结构化查询语言)进行数据操作,支持ACID(原子性、一致性、隔离性和持久性)属性,确保数据的一致性和完整性。 2. **分布式数据库**:Oracle支持...

    oracle培训公司笔记1

    - **Linux**:一种免费使用的类Unix操作系统,是Oracle等数据库运行的重要平台之一。 - 学习目标:熟悉一个特定的Linux发行版(如Ubuntu或CentOS),为后续的学习打下坚实的基础。 #### 4. .NET与Oracle - **.NET**...

    Oracle9i备课笔记——吕海东

    Oracle9i备课笔记——吕海东 第1讲 Oracle9i简介 目的: 1. 了解数据库的发展,关系数据库的基本原理。 2. 了解目前市场上流行的数据库产品及特点 3. 了解Oracle数据库的发展 4. 掌握Oracle9i产品系列 5. 掌握Oracle...

    Oracle初学者笔记

    ### Oracle初学者笔记知识点解析 #### 一、Oracle网络通信机制与安全性 **1.1 Net8协议** - **概述**: Oracle使用Net8协议在客户端和服务器之间进行数据传输。 - **加密与解密**: 该协议支持加密功能,确保数据在...

    ORACLE_ODI笔记

    5. **导入知识模块**:知识模块是ODI的关键,它们包含了特定操作的逻辑,通常位于安装目录下的xml-reference文件夹。 6. **新建模型**:模型定义了数据的逻辑结构,可以逆向工程从数据库中生成模型。 7. **新建接口*...

    XML笔记(个人总结)

    通过DOM可以将XML文档视为树状结构,便于操作。 #### 14. SAX (Simple API for XML) SAX提供了一种基于事件驱动的方式来解析XML文档,适用于大文档。 #### 15. XPath XPath是一种在XML文档中查找信息的语言,它...

    XML高级编程学习笔记

    DOM将整个XML文档加载到内存中形成一棵树形结构,便于遍历和操作;而SAX则采用事件驱动的方式,逐行读取文档,节省内存但需要编写更多代码。 1.2 XML 元素、属性和名称空间 XML元素是文档的基本构建块,它们可以...

    oracle课堂笔记

    根据提供的信息,我们可以总结出这份“Oracle课堂笔记”主要涵盖了Oracle数据库的基础知识、安装过程以及SQL语言的基本操作。下面将详细解析这些知识点。 ### Oracle基础知识 #### Oracle简介 Oracle是一种关系型...

    tarena达内大部分笔记(xml,struts,spring,hibernate,oracle,jsp,jdbc,corejava,servlet)

    内容很多,包含达内大部分笔记,如果你感到哪里不足,请留言,我继续补充。 目录如下 ├─xml ├─struts ├─spring │ ├─spring-note │ └─spring-day2PM │ ├─exec │ ├─aop3 │ ├─aop2 │ └─aop1 ├...

    oracle学习笔记

    linux 熟悉一种新的操作系统 软件工厂 学到的知识 去做一个项目 课程安排 linux操作系统 4天 数据结构 5天 DOTNET介绍 4天 ORACLE ORACLE数据库 10天 XML语言 5天 J2EE JSP/servlet 12天 EJB 3天 ...

    OracleEBS-WebService开发笔记.pdf

    **OracleEBS-WebService开发笔记** 是一份详尽的文档,旨在介绍如何利用 WebService 技术进行 Oracle E-Business Suite (EBS) 的集成开发。该文档由 JarWang(王重东)编写,创建日期为2011年4月5日,当前版本为1.0...

    oracle笔记

    Oracle 11g是一款强大的关系型数据库管理系统,...综上所述,“Oracle笔记”应该涵盖了这些内容,为学习者提供了一个全面了解和操作Oracle 11g数据库的框架。通过深入学习和实践,可以掌握这个强大的数据库系统的精髓。

    activiti 5.8 oracle10g demo安装笔记

    1、activiti 5.8 oracle10g demo安装笔记.txt 2、关键配置文件附件: build.db.properties build.properties build.xml oracle.data.sql

    MLDN魔乐科技JAVA培训_Oracle课堂笔记

    "MLDN魔乐科技JAVA培训_Oracle课堂笔记" 是一个与Java编程和Oracle数据库相关的学习资源,由知名的IT培训机构MLDN魔乐科技提供。这个标题表明这是一份专门针对Java程序员或者对Oracle数据库感兴趣的学员的培训资料,...

    Oracle_OAF_开发笔记

    Oracle OAF(Oracle Application Framework)是Oracle E-Business Suite中的一个关键组件,用于构建和定制企业级的应用程序。本文档是一份由Jarwang(王重东)编写的开发笔记,后由Cao Liankai(曹连凯)在2010年...

Global site tag (gtag.js) - Google Analytics