MySQL提供了原生的Load Xml Data Infile命令,可以直接将符合规范的XML文件内容导入到数据库表中,不需要借助第三方工具或者额外编写XML解析代码,能够大幅提升批量数据导入的效率。

Load Xml Data Infile命令的基本语法
该命令的核心作用是从服务器本地的XML文件中读取数据,然后插入到指定的数据表中,基本语法格式如下:
LOAD XML [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE 'xml文件路径' [REPLACE | IGNORE] INTO TABLE 表名 [CHARACTER SET 字符集名称] [ROWS IDENTIFIED BY '<行标识标签>'] [IGNORE 忽略行数 LINES] [(字段1,字段2,...)]
语法参数说明
- LOW_PRIORITY/CONCURRENT:控制导入时的优先级,LOW_PRIORITY会让导入操作等待其他读表操作完成,CONCURRENT允许导入时其他会话读取表数据。
- LOCAL:加上该参数表示从客户端本地读取XML文件,不加则从MySQL服务器所在机器的本地路径读取文件。
- REPLACE/IGNORE:遇到主键或唯一键冲突时的处理策略,REPLACE会替换已有记录,IGNORE会跳过冲突记录。
- ROWS IDENTIFIED BY:指定XML中代表一行数据的标签名,默认是<row>。
XML文件的格式要求
Load Xml Data Infile命令对XML文件的格式有明确要求,只有符合规范的XML才能被正确解析:
标准格式示例
假设我们要导入用户数据到user表,user表有id、name、age三个字段,对应的XML文件内容如下:
<?xml version="1.0" encoding="utf-8"?>
<data>
<row>
<id>1</id>
<name>张三</name>
<age>25</age>
</row>
<row>
<id>2</id>
<name>李四</name>
<age>28</age>
</row>
</data>
这里的每个<row>标签对应数据库表中的一行数据,标签名需要和表的字段名完全一致,命令会自动将标签内的内容匹配到对应的字段。
自定义行标识标签的格式
如果XML中代表行的标签不是默认的<row>,比如是<user>,那么需要在命令中指定ROWS IDENTIFIED BY '<user>',示例如下:
<?xml version="1.0" encoding="utf-8"?>
<user_list>
<user>
<id>3</id>
<name>王五</name>
<age>30</age>
</user>
</user_list>
完整导入示例
第一步:创建测试表
首先在MySQL中创建对应的user表:
CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(50) DEFAULT NULL, `age` int(11) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
第二步:执行导入命令
假设XML文件放在服务器的/tmp/user.xml路径下,执行以下命令导入数据:
LOAD XML INFILE '/tmp/user.xml' INTO TABLE user CHARACTER SET utf8mb4 ROWS IDENTIFIED BY '<row>';
第三步:验证导入结果
导入完成后查询表数据,确认数据是否正确写入:
SELECT * FROM user;
如果输出结果包含XML文件中的三条用户记录,说明导入成功。
常见问题及解决方案
权限不足问题
如果执行命令时提示权限错误,需要确认当前MySQL用户是否拥有FILE权限,没有的话需要管理员执行以下命令授予权限:
GRANT FILE ON *.* TO '用户名'@'主机地址'; FLUSH PRIVILEGES;
文件找不到问题
如果提示文件不存在,首先确认路径是否正确,其次注意如果没加LOCAL参数,文件必须放在MySQL服务器所在的机器上,并且MySQL进程有权限读取该文件路径。如果文件在客户端本地,需要加上LOCAL参数。
字符编码问题
如果导入后出现乱码,需要确认XML文件的编码和命令中指定的CHARACTER SET参数一致,同时表的字符集也要匹配,通常推荐使用utf8mb4编码兼容更多字符。
字段不匹配问题
如果XML中的标签名和表字段名不一致,可以在命令末尾指定字段映射关系,示例如下:
LOAD XML INFILE '/tmp/user.xml' INTO TABLE user CHARACTER SET utf8mb4 ROWS IDENTIFIED BY '<row>' (name,age); -- 只导入name和age字段,id使用自增
使用限制
Load Xml Data Infile命令虽然方便,但也有一定的使用限制:
- 只支持结构简单的XML文件,不支持嵌套层级复杂的XML结构,如果XML嵌套过多,建议先解析后再导入。
- 导入文件大小受MySQL的
max_allowed_packet参数限制,大文件需要调大该参数的值。 - LOCAL模式导入时,文件是从客户端读取,传输过程会占用一定的网络带宽,大文件不建议使用LOCAL模式。
MySQLLoad_Xml_Data_InfileXML导入数据库数据导入修改时间:2026-06-26 09:30:30