我们如何从XML文件中将数据加载到Mysql表? 有没有办法从XML文件读取数据并写入MySql数据库.. 我在XML Files中有大量数据。
先谢谢你的帮助。
答案 0 :(得分:5)
尝试LOAD XML函数(MySQL 6.0)。以下是参考手册中的示例代码:
使用包含以下内容的 person.xml
<?xml version="1.0"?>
<list>
<person person_id="1" fname="Pekka" lname="Nousiainen"/>
<person person_id="2" fname="Jonas" lname="Oreland"/>
<person person_id="3"><fname>Mikael</fname><lname>Ronström</lname></person>
<person person_id="4"><fname>Lars</fname><lname>Thalmann</lname></person>
<person><field name="person_id">5</field><field name="fname">Tomas</field><field name="lname">Ulin</field></person>
<person><field name="person_id">6</field><field name="fname">Martin</field><field name="lname">Sköld</field></person>
</list>
你会像这样创建一个表:
CREATE TABLE person (
person_id INT NOT NULL PRIMARY KEY,
fname VARCHAR(40) NULL,
lname VARCHAR(40) NULL,
created TIMESTAMP
);
并使用以下命令导入XML:
LOAD XML LOCAL INFILE 'person.xml'
INTO TABLE person
ROWS IDENTIFIED BY '<person>';
或者,如果您运行的是MySQL 5.0,则可以使用LOAD_FILE将整个XML文档作为字符串加载到单个列中,然后使用MySQL的XPath功能对其进行解析。
MySQL.com上的这篇文章有更多细节:Using XML in MySQL 5.1 and 6.0。
答案 1 :(得分:1)
如果您正在寻找一个简单的解决方案,Navicat有一个非常简单的xml导入功能。
答案 2 :(得分:0)
为什么不使用XSL将XML转换为标准的SQL insert语句,然后使用mysql客户端中的“source”命令来读取输出?