0

0

Oracle的XMLType数据类型怎么用

幻夢星雲

幻夢星雲

发布时间:2026-01-05 10:39:27

|

277人浏览过

|

来源于php中文网

原创

Oracle XMLType是支持XPath/XQuery、索引及节点操作的结构化XML类型,非简单CLOB;需用createXML插入、extractValue等函数查询、updateXML等修改,配合XMLIndex提升性能。

oracle的xmltype数据类型怎么用

Oracle 的 XMLType 是专为存储和操作 XML 数据设计的内置数据类型,不是简单存成 CLOB 就完事——它支持 XPath 查询、XQuery、索引、节点增删改查等结构化能力。用对了,XML 就能像关系表一样高效检索;用错了,容易卡在取值失败、编码报错或超 4KB 插入异常上。

建表与插入:从定义到写入

创建含 XMLType 列的表很直接,但注意命名空间和编码细节:

  • 建表语句示例:CREATE TABLE config_data (id NUMBER PRIMARY KEY, cfg XMLTYPE);
  • 插入时推荐用 XMLType.createXML() 而非裸字符串,尤其含中文时要显式声明编码:
    INSERT INTO config_data VALUES (1, XMLType.createXML('10.1.1.1'));
  • 若 XML 超过 4KB(比如大配置文件),不能直接拼接字符串插入,应先写入临时 CLOB 表,再用 XMLType.createXML(SELECT content FROM temp_clob WHERE id = 1) 转换。

查询提取:用对 extract / extractValue / existsNode

别用 SELECT * 直接查 XMLType 字段——它不显示内容。必须用解析函数:

  • extractValue() 最常用,返回字符串值:
    SELECT extractValue(cfg, '/config/db/host') AS host FROM config_data WHERE id = 1;
  • existsNode() 用于 WHERE 条件判断节点是否存在(返回 1 或 0):
    SELECT * FROM config_data WHERE existsNode(cfg, '/config/db[@namecn="主库"]') = 1;
  • 若需返回 XML 片段(仍为 XMLType 类型),用 extract()
    SELECT cfg.extract('/config/db') FROM config_data;
  • 想看完整 XML 内容做调试?加 getClobVal()
    SELECT cfg.getClobVal() FROM config_data WHERE id = 1;

更新与修改:节点级操作不是 update set 字段=xxx

XMLType 不支持直接 UPDATE SET 字段='新XML',必须用专用函数精准定位修改:

魔法映像企业网站管理系统
魔法映像企业网站管理系统

技术上面应用了三层结构,AJAX框架,URL重写等基础的开发。并用了动软的代码生成器及数据访问类,加进了一些自己用到的小功能,算是整理了一些自己的操作类。系统设计上面说不出用什么模式,大体设计是后台分两级分类,设置好一级之后,再设置二级并选择栏目类型,如内容,列表,上传文件,新窗口等。这样就可以生成无限多个二级分类,也就是网站栏目。对于扩展性来说,如果有新的需求可以直接加一个栏目类型并新加功能操作

下载
  • 修改属性或文本节点:UPDATE config_data SET cfg = updateXML(cfg, '/config/db/@namecn', '生产库') WHERE id = 1;
  • 追加子节点:UPDATE config_data SET cfg = appendChildXML(cfg, '/config/db', XMLType('1521')) WHERE id = 1;
  • 删除节点:UPDATE config_data SET cfg = deleteXML(cfg, '/config/db/port') WHERE id = 1;
  • 注意:所有这些函数都要求路径存在,否则整条 UPDATE 失败(不会静默忽略)。

性能与索引:查得慢?该建 XMLIndex 了

没索引时,每次 extractValue() 都要全文档解析,大数据量下明显变慢。Oracle 提供三类 XML 索引:

  • PATH 索引:加速带固定路径的查询,如 /config/db/host —— 最常用:
    CREATE INDEX idx_cfg_host ON config_data (cfg) INDEXTYPE IS XDB.XMLINDEX PARAMETERS ('PATHS (INCLUDE (/config/db/host))');
  • VALUE 索引:适合按节点值模糊搜索,比如 WHERE extractValue(...) LIKE '%10.%'
  • STRUCTURED 索引(旧称 EXTRACT):把特定路径映射为虚拟列,可走普通 B-Tree 索引,适合高频等值查询。

基本上就这些。关键不是记住所有函数名,而是理解:XMLType 是“可查询的 XML”,不是“可存储的字符串”。路径写对、函数选对、索引跟上,就能稳住性能。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

299

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

218

2025.10.31

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1860

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2084

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

957

2024.11.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

253

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1458

2023.10.24

PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.07

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.3万人学习

Java 教程
Java 教程

共578课时 | 43.1万人学习

oracle知识库
oracle知识库

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号