Maison > base de données > tutoriel mysql > le corps du texte

Pourquoi ma déclaration préparée par PDO Fetch() duplique-t-elle les résultats ?

Barbara Streisand
Libérer: 2024-11-01 20:47:30
original
347 Les gens l'ont consulté

Why is my PDO Prepared Statement Fetch() Duplicating Results?

PDO Prepared Statement Fetch() Duplication des résultats

Problème

Un script PHP utilisant des instructions préparées PDO et fetch() génère des données en double dans un fichier CSV. Chaque ligne de la base de données est répétée deux fois, ce qui entraîne des valeurs de colonne doublées.

Analyse

Auparavant, lorsque vous n'utilisiez pas PDO, la requête fonctionnait comme prévu. Par conséquent, le problème peut résider dans l'utilisation de fetch().

Résolution

En spécifiant le mode de récupération des données souhaité lors de l'appel de fetch(), le problème des résultats en double peut être résolu. Il existe deux options :

  • PDO::FETCH_ASSOC: Renvoie un tableau indexé par les noms de colonnes.
  • PDO::FETCH_NUM: Renvoie un tableau indexé par les numéros de colonnes.

Pour implémenter cela, modifiez le code comme suit :

<code class="php">while ($rows_get_rows = $result_get_rows->fetch(PDO::FETCH_ASSOC)) {
  $csv .= '"'.join('","', str_replace('"', '""', $rows_get_rows))."\"\n";
}</code>
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal