我正在使用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循环出错了,我知道对于某些人来说这可能很容易,但是现在我无法自己解决它。任何帮助将不胜感激。
答案 0 :(得分:1)
您需要在最里面的foreach
之外构建完整的查询。这样的事情将是一个好的开始。该线程应该能够帮助您使绑定与mysqli
,MySQLI 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);
}
}