使用simpleXML将xml数据插入mysql

时间:2014-08-29 08:03:03

标签: php mysql xml simplexml

我必须将数据从xml插入数据库,但我对此特定数据有疑问

<specifications>
    <attribute_group name="attributeGroup1">
        <attribute name="attribute1">                   
            <value>value1</value>
        </attribute>
        <attribute name="attribute2">                   
            <value>value2</value>
        </attribute>
        <attribute name="attribute3">                   
            <value>value3</value>
        </attribute>
    </attribute_group>
<specifications>

我需要在数据库中插入类似

的内容
INSERT INTO specs (attr_group,attr_name, attr_value) VALUES ('$attr_group','$attr_name', '$attr_value')

问题是我不知道如何为此创建foreach。

1 个答案:

答案 0 :(得分:3)

只需使用SimpleXML,即可访问这些值,只需执行正常的foreach以及插入代码(MySQLi或PDO)。

示例代码:

$db = new mysqli('localhost', 'username', 'password', 'database');
$xml = simplexml_load_string($xml_string); // or load file
$insert = $db->prepare('INSERT INTO specs (attr_group,attr_name, attr_value) VALUES (?, ?, ?)');

foreach($xml as $group) {
    $attribute_group = (string) $group->attributes()['name'];
    foreach($group as $attr) {
        $attribute = (string) $attr->attributes()['name'];
        $value = (string) $attr->value;
        $insert->bind_param('sss', $attribute_group, $attribute, $value);
        $insert->execute();
    }
}