XML到数据库-foreach循环到MySQL

时间:2018-12-10 13:45:57

标签: php mysql xml foreach simplexml

我正在使用simpleXML提取XML文件,并希望通过foreach循环将这些值存储在数据库中。这是我的代码:

<?php
$xml = simplexml_load_string('XML-FILE');

foreach ($xml->METADATA->DATA as $item) {
    foreach ($item->children() as $child) {
        $sel_stmt = "INSERT INTO dwh_xml (".$child->getName().") VALUES ('".$child."') ";
        directSQL($sel_stmt);
    }
}
?>

我的XML文件如下:

<xml version="1.0" encoding="utf-8">
    <METADATA>
        <DATA>
            <FIELD_1>001</FIELD_1>
            <FIELD_2>ENTRY_2</FIELD_2>
            <FIELD_3>ENTRY_3</FIELD_3>
            <FIELD_4>ENTRY_4</FIELD_4>
            <FIELD_5>ENTRY_5</FIELD_5>
            <FIELD_6>000003</FIELD_6>
            <FIELD_7>ENTRY_7</FIELD_7>
            <FIELD_8>ENTRY_8</FIELD_8>
            <FIELD_9>ENTRY_9</FIELD_9>
            <FIELD_10>ENTRY_10</FIELD_10>
            <FIELD_11>ENTRY_11</FIELD_11>
            <FIELD_12>ENTRY_12</FIELD_12>
            <FIELD_13>ENTRY_13</FIELD_13>
        </DATA>
    <METADATA>
</xml>

正在导入数据库,但对于每个值,它都会生成一个新条目,并且我不知道必须如何更改上述代码,以便它将成为具有ID的数据库中的单个条目。这是我的测试条目的屏幕截图:

enter image description here

在这里您可以看到它的外观: enter image description here

我知道我的foreach循环出错了,我知道对于某些人来说这可能很容易,但是现在我无法自己解决它。任何帮助将不胜感激。

1 个答案:

答案 0 :(得分:1)

您需要在最里面的foreach之外构建完整的查询。这样的事情将是一个好的开始。该线程应该能够帮助您使绑定与mysqliMySQLI binding params using call_user_func_array一起使用。使用PDO,您只需将$params传递给execute函数。

foreach ($xml->METADATA->DATA as $item) {
    foreach ($item->children() as $child) {
        $cols[] = $child->getName();
        $params[] = $child->nodeValue;
    }
    if(!empty($params)) {
         $columns = implode(',', $cols);
         $placeholders = rtrim(str_repeat('?, ', count($params)), ', ');
         $sql = 'INSERT INTO dwh_xml ( ' . $columns . ') VALUES(' . $placeholders . ')';
         $stmt = $db_con->prepare($sql);
         $stmt->execute();
         unset($params, $cols, $placeholders);
    }
}

https://3v4l.org/nhJi7