foreach
peut itérer n'importe quel tableau ou objet qui implémente traversable. Le résultat de PDOStatement::fetch()
est l'enregistrement/ligne. Fournissez simplement l'instruction à foreach.
foreach($statement as $row) { ...
La meilleure API pour les vidages comme celui-ci est XMLWriter . Il écrit le résultat directement dans un flux, sans d'abord stocker tout le document en mémoire. L'utilisation d'une API XML prendra également en charge l'échappement si nécessaire. Voici un petit exemple :
$statement = [
[ 'name' => 'one', 'location' => '...', /* ... */],
[ 'name' => 'two', 'location' => '...', /* ... */]
];
$xmlWriter = new XMLWriter();
$xmlWriter->openUri('php://stdout');
$xmlWriter->startDocument();
$xmlWriter->setIndent(2);
$xmlWriter->startElement('markers');
foreach ($statement as $row) {
$xmlWriter->startElement('marker');
$xmlWriter->writeAttribute('name', $row['name']);
/* other attributes ... */
$xmlWriter->endElement();
}
$xmlWriter->endElement();
$xmlWriter->endDocument();
Sortie :
<?xml version="1.0"?>
<markers>
<marker name="one"/>
<marker name="two"/>
</markers>
Dans DOM, vous créez, ajoutez et configurez des nœuds. Voici un petit exemple :https://stackoverflow.com/a/21760903/2265374