如何操作 XML 数据_XMLTYPE 与 EXTRACT 函数解析节点

Oracle中EXTRACT返回空因XPath 1.0限制、命名空间未声明、未调用getStringVal();推荐改用XMLTABLE,它支持XPath 2.0、统一声明命名空间、天然返回SQL类型值。Oracle 里用 EXTRACT 解析 XMLTYPE 为啥总返回空?因为 extract 在 oracle 10g/11g 中默认只支持 xpath 1.0,且对命名空间、根节点层级、数据类型敏感------不是写对路径就能出结果。必须显式声明命名空间(哪怕文档没声明),否则 EXTRACT 直接忽略匹配节点XMLTYPE 字符串若以 <?xml version="1.0"?> 开头,但没指定编码,某些版本会解析失败,建议用 XMLTYPE.createXML() 构造而非直接字符串转返回值是 XMLTYPE,不是字符串,想取文本得链式调用 .getStringVal(),漏掉这步就看到空或 NULL示例:SELECT EXTRACT(xml_col, '/root/item/name/text()', 'xmlns="http://example.com"')<br> .getStringVal() AS name_val<br>FROM my_table;替换 EXTRACT:为什么现在更推荐用 XMLTABLEEXTRACT 在 Oracle 12c+ 已被标记为"deprecated",官方明确建议迁移到 XMLTABLE------它支持完整 XPath 2.0、能同时提取多个字段、天然处理命名空间,且性能更稳定。XMLTABLE 把 XML 当作虚拟表查,避免嵌套 EXTRACT + getStringVal() 的冗余链式调用命名空间用 XMLNAMESPACES() 一次性声明,不用在每个路径里重复写遇到空节点不会报错,而是返回 NULL,和 SQL 行为一致,便于后续 NVL 或过滤示例:SELECT x.name, x.price<br>FROM my_table,<br> XMLTABLE(XMLNAMESPACES('http://example.com' AS "ns"),<br> '/ns:root/ns:item'<br> PASSING xml_col<br> COLUMNS name VARCHAR2(50) PATH 'ns:name',<br> price NUMBER PATH 'ns:price') x;XMLTYPE 存储选 CLOB 还是 BINARY XML?取决于查询频率和更新模式。不是越大越好,也不是越小越快。 Trenz AI驱动的社交电商营销平台,专为TikTok Shop设计

相关推荐
杨充22 分钟前
1.3 浮点型数据设计灵魂
开发语言·python·算法
meilindehuzi_a1 小时前
深入浅出数据结构:Python 字典(Dict)与集合(Set)的哈希表底层全链路追踪
数据结构·python·散列表
Lucas凉皮1 小时前
20243408 2025-2026-2 《Python程序设计》综合实践报告
python·实验报告
键盘上的猫头鹰1 小时前
【MySQL 教程(八)】索引、事务、用户管理、导入导出与分页查询
数据库·python·mysql
Royzst1 小时前
数据库知识点
数据库
雪的季节2 小时前
企业级 Qt 全功能项目
开发语言·数据库·qt
薛定谔的猫-菜鸟程序员2 小时前
2小时智能体开发一个智能体?我用CodeArts Agent 和 AtomCode 开发了一个适老化智能体。
人工智能·python·agent
宋浮檀s2 小时前
应急响应——Web漏洞:命令执行+SSRF+弱口令
运维·数据库·sql·网络安全·oracle·应急响应
bigfootyazi3 小时前
python爬虫-基本库-urllib库(常用速查)
开发语言·爬虫·python
瑶总迷弟3 小时前
使用 mis-tei 在昇腾310P上部署 bge-m3模型
pytorch·python·华为·语言模型·自然语言处理·cnn·unix