2

すべてのデータセットが xml ファイルに書き込まれるわけではないことを除いて、MYSQL データベースで php クエリを使用し、DOM を使用して xml ファイルを出力すると、すべてが正常に機能します。たとえば、期待される結果の数を出すことができます:

$num_results = mysql_num_rows($result);
echo $num_results;

これはたとえば 20 ですが、保存された xml ファイル (「auswertung.xml」) には 19 エントリしかありません。毎回、最初のデータセットは書き込まれません。何が間違っている可能性がありますか?

関連するコードは次のとおりです。

// Start XML file, create parent node
$dom = new DOMDocument("1.0");
$node = $dom->createElement("markers");
$parnode = $dom->appendChild($node);

// Opens a connection to a mySQL server
$connection=mysql_connect ($dbhost, $username, $password);
if (!$connection) {
    die('Not connected : ' . mysql_error());
}

// Set the active mySQL database
$db_selected = mysql_select_db($database, $connection);
if (!$db_selected) {
    die ('Can\'t use db : ' . mysql_error());
}


$query = "SELECT * FROM Herpeto WHERE Art like '$Art' ORDER BY ID ASC";
$result = mysql_query($query) or die ("Error in query: $query " . mysql_error());
$row = mysql_fetch_array($result);
$num_results = mysql_num_rows($result);

// Iterate through the rows, adding XML nodes for each
echo $num_results;
while ($row = @mysql_fetch_assoc($result)){
// ADD TO XML DOCUMENT NODE
$node = $dom->createElement("marker");
$newnode = $parnode->appendChild($node);

$newnode->setAttribute("Art", $row['Art']);
$newnode->setAttribute("Anzahl", utf8_encode ($row['Anzahl']));
$newnode->setAttribute("Status", $row['Status']);
$newnode->setAttribute("Stadt", utf8_encode($row['Stadt']));
$newnode->setAttribute("Fundstelle", utf8_encode($row['Fundstelle']));
$newnode->setAttribute("Bemerkung", utf8_encode($row['Bemerkung']));
$newnode->setAttribute("Tag", utf8_encode ($row['Tag']));
$newnode->setAttribute("Monat", utf8_encode ($row['Monat']));
$newnode->setAttribute("Jahr", utf8_encode ($row['Jahr']));
$newnode->setAttribute("Beobachter", utf8_encode($row['Beobachter']));
$newnode->setAttribute("lat", $row['lat']);
$newnode->setAttribute("lng", $row['lng']);
}

$dom->save('auswertung.xml');
4

1 に答える 1

1

mysql_fetch_array()実際にxml出力を作成するwhileループに結果を渡す前に結果を呼び出すため、xml出力で20行のうち19行を取得します。

$row = mysql_fetch_array($result); // <-- here you get the first row
//...
while ($row = @mysql_fetch_assoc($result)){ // <-- now while loop starts from 2nd row
于 2012-09-02T20:32:13.550 に答える