

新闻资讯
技术学院ExtractValue和UpdateXML是MySQL中已弃用的XML处理函数,仅支持XPath 1.0子集,不支持谓词函数、命名空间、动态路径及节点增删;推荐改用JSON函数替代。
ExtractValue(xml_str, xpath_expr) 返回的是字符串,不是节点集。它内部调用的是 libxml2 的 XPath 1.0 实现,不支持 //node[1] 这类位置路径以外的谓词(比如 //item[@id='100'] 可以,但 //item[position()=1] 会报错),也不支持函数调用(如 count()、string-length())。
常见错误现象:ExtractValue(' 返回空 —— 因为 text() 不被支持;正确写法是 '//a',它会自动提取文本内容。
CONCAT('//', @tag) 直接传入)UpdateXML(xml_str, xpath_expr, new_xml) 把第一个匹配到的节点替换成 new_xml 字符串。注意:它不是“修改节点内容”,而是“用新 XML 片段替换整个节点”。例如:
SELECT UpdateXML('Alice ', '/root/user', 'Bob ');
结果是 。但如果想只改文本内容(保留属性),就得手动拼出完整新节点,没法只更新 text() 部分。
xpath_expr 不匹配任何节点,原 XML 字符串原样返回(不会报错)new_xml 是纯字符串,MySQL 不校验其是否合法 XML;插入恶意字符串(如未闭合标签)会导致后续 ExtractValue 解析失败从 MySQL 8.0.26 开始,文档明确标注 ExtractValue 和 UpdateXML 为“deprecated”,未来版本可能移除。它们底层依赖 libxml2,而该库在 MySQL 中长期存在内存管理缺陷(如某些畸形 XML 触发崩溃),实际线上环境出现过 segfault。
JSON 类型,用 JSON_EXTRACT、JSON_SET、JSON_REPLACE 操作,性能更好、语法更直观、无 XML 解析风险MySQL 5.7 默认开启 sql_mode=STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION,但 ExtractValue 对非法 XML 的容忍度反而比 8.0 更高 —— 有些在 5.7 返回空字符串的 case,在 8.0 直接返回 NULL,导致 WHERE ExtractValue(...) = 'x' 查询意外失效。
,补上 IS NOT NULL 或 IFNULL 判断latin1 而字段是 utf8mb4,ExtractValue 可能截断中文(因按字节解析 XPath)