Maison  >  Article  >  base de données  >  Pourquoi ma déclaration préparée par PDO Fetch() duplique-t-elle les résultats ?

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

Barbara Streisand
Barbara Streisandoriginal
2024-11-01 20:47:30281parcourir

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>

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!

Déclaration:
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