xml到数据库-foreach循环到mysql

mm9b1k5b  于 2021-06-17  发布在  Mysql
关注(0)|答案(1)|浏览(414)

我正在用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的单个条目。下面是我的测试条目的屏幕截图:

在这里你可以看到它应该是什么样子:

我知道我的foreach循环有问题,我知道这对你们中的一些人来说可能很容易,但现在我无法自己修复它。任何帮助都将不胜感激。

zi8p0yeb

zi8p0yeb1#

您需要在最内部的外部构建完整的查询 foreach . 像这样的事情将是一个好的开始。这个线程应该能够帮助您获得绑定工作 mysqli ,mysqli绑定参数使用call\u user\u func\u数组。有了pdo你就可以通过了 $paramsexecute 功能。

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

相关问题