PDOStatement::fetchAll
(PHP 5 >= 5.1.0, PHP 7, PECL pdo >= 0.1.0)
PDOStatement::fetchAll — Retourne un tableau contenant toutes les lignes du jeu d'enregistrements
Description
$fetch_style
[, mixed $fetch_argument
[, array $ctor_args
= array()
]]] )Liste de paramètres
-
fetch_style
-
Contrôle le contenu du tableau retourné comme documenté dans la fonction PDOStatement::fetch(). Valeur par défaut :
PDO::ATTR_DEFAULT_FETCH_MODE
(qui prend sa valeur par défaut dePDO::FETCH_BOTH
).Pour retourner un tableau contenant toutes les valeurs d'une seule colonne depuis le jeu de résultats, spécifiez
PDO::FETCH_COLUMN
. Vous pouvez spécifier quelle colonne vous voulez avec le paramètrefetch_argument
.Pour récupérer uniquement les valeurs uniques d'une seule colonne depuis le jeu de résultats, utilisez
PDO::FETCH_COLUMN
avecPDO::FETCH_UNIQUE
.Pour retourner un tableau associatif groupé par les valeurs d'une colonne spécifique, utilisez
PDO::FETCH_COLUMN
avecPDO::FETCH_GROUP
. -
fetch_argument
-
Cet argument prend une valeur différente en fonction de la valeur de l'argument
fetch_style
:-
PDO::FETCH_COLUMN
: Retourne le numéro de la colonne demandée (indexée à partir de 0). -
PDO::FETCH_CLASS
: Retourne une instance de la classe désirée. Les colonnes sélectionnées sont liées aux attributs de la classe. -
PDO::FETCH_FUNC
: Retourne la valeur de retour de la fonction de rappel précisée.
-
-
ctor_args
-
Arguments du constructeur personnalisé de la classe lorsque l'argument
fetch_style
est àPDO::FETCH_CLASS
.
Valeurs de retour
PDOStatement::fetchAll() retourne un tableau contenant toutes les lignes du jeu d'enregistrements. Le tableau représente chaque ligne comme soit un tableau de valeurs des colonnes, soit un objet avec des propriétés correspondant à chaque nom de colonne.
L'utilisation de cette méthode pour récupérer de gros jeux de résultats peut augmenter les ressources du système, mais également ces ressources. Plutôt que de récupérer toutes les données et de les manipuler avec PHP, utilisez le serveur de base de données pour manipuler les jeux de résultats. Par exemple, utilisez les clauses WHERE et ORDER BY dans vos requêtes SQL pour restreindre les résultats avant de les récupérer et de les traiter avec PHP.
Exemples
Exemple #1 Récupération de toutes les lignes d'un jeu de résultats
<?php
$sth = $dbh->prepare("SELECT nom, couleur FROM fruit");
$sth->execute();
/* Récupération de toutes les lignes d'un jeu de résultats */
print("Récupération de toutes les lignes d'un jeu de résultats :\n");
$result = $sth->fetchAll();
print_r($result);
?>
L'exemple ci-dessus va afficher quelque chose de similaire à :
Récupération de toutes les lignes d'un jeu de résultats : Array ( [0] => Array ( [nom] => apple [0] => apple [couleur] => red [1] => red ) [1] => Array ( [nom] => pear [0] => pear [couleur] => green [1] => green ) [2] => Array ( [nom] => watermelon [0] => watermelon [couleur] => pink [1] => pink ) )
Exemple #2 Récupération de toutes les valeurs d'une seule colonne depuis un jeu de résultats
L'exemple suivant montre comment retourner toutes les valeurs d'une seule colonne depuis un jeu de résultats, même si la requête SQL retourne plusieurs colonnes par lignes.
<?php
$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
/* Récupération de toutes les valeurs de la première colonne */
$result = $sth->fetchAll(PDO::FETCH_COLUMN, 0);
var_dump($result);
?>
L'exemple ci-dessus va afficher quelque chose de similaire à :
Array(3) ( [0] => string(5) => apple [1] => string(4) => pear [2] => string(10) => watermelon )
Exemple #3 Grouper toutes les valeurs d'une seule colonne
L'exemple suivant montre comment retourner un tableau associatif groupé par les valeurs de la colonne spécifiée d'un jeu de résultats. Le tableau contient trois clés : les valeurs apple et pear sont retournées sous la forme de tableaux qui contiennent deux couleurs différentes, tandis que watermelon est retourné sous la forme d'un tableau qui contient uniquement une seule couleur.
<?php
$insert = $dbh->prepare("INSERT INTO fruit(name, colour) VALUES (?, ?)");
$insert->execute(array('apple', 'green'));
$insert->execute(array('pear', 'yellow'));
$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
/* Grouper les valeurs de la première colonne */
var_dump($sth->fetchAll(PDO::FETCH_COLUMN|PDO::FETCH_GROUP));
?>
L'exemple ci-dessus va afficher quelque chose de similaire à :
array(3) { ["apple"]=> array(2) { [0]=> string(5) "green" [1]=> string(3) "red" } ["pear"]=> array(2) { [0]=> string(5) "green" [1]=> string(6) "yellow" } ["watermelon"]=> array(1) { [0]=> string(5) "pink" } }
Exemple #4 Instancier une classe pour chaque résultat
L'exemple suivant montre le comportement de
PDO::FETCH_CLASS
.
<?php
class fruit {
public $name;
public $colour;
}
$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
$result = $sth->fetchAll(PDO::FETCH_CLASS, "fruit");
var_dump($result);
?>
L'exemple ci-dessus va afficher quelque chose de similaire à :
array(3) { [0]=> object(fruit)#1 (2) { ["name"]=> string(5) "apple" ["colour"]=> string(5) "green" } [1]=> object(fruit)#2 (2) { ["name"]=> string(4) "pear" ["colour"]=> string(6) "yellow" } [2]=> object(fruit)#3 (2) { ["name"]=> string(10) "watermelon" ["colour"]=> string(4) "pink" } [3]=> object(fruit)#4 (2) { ["name"]=> string(5) "apple" ["colour"]=> string(3) "red" } [4]=> object(fruit)#5 (2) { ["name"]=> string(4) "pear" ["colour"]=> string(5) "green" } }
Exemple #5 Appel d'une fonction pour chaque résultat
L'exemple suivant montre le comportement de
PDO::FETCH_FUNC
.
<?php
function fruit($name, $colour) {
return "{$name}: {$colour}";
}
$sth = $dbh->prepare("SELECT name, colour FROM fruit");
$sth->execute();
$result = $sth->fetchAll(PDO::FETCH_FUNC, "fruit");
var_dump($result);
?>
L'exemple ci-dessus va afficher quelque chose de similaire à :
array(3) { [0]=> string(12) "apple: green" [1]=> string(12) "pear: yellow" [2]=> string(16) "watermelon: pink" [3]=> string(10) "apple: red" [4]=> string(11) "pear: green" }
Voir aussi
- PDO::query() - Exécute une requête SQL, retourne un jeu de résultats en tant qu'objet PDOStatement
- PDOStatement::fetch() - Récupère la ligne suivante d'un jeu de résultats PDO
- PDOStatement::fetchColumn() - Retourne une colonne depuis la ligne suivante d'un jeu de résultats
- PDO::prepare() - Prépare une requête à l'exécution et retourne un objet
- PDOStatement::setFetchMode() - Définit le mode de récupération par défaut pour cette requête
Version en cache
22/01/2025 20:11:45 Cette version de la page est en cache (à la date du 22/01/2025 20:11:45) afin d'accélérer le traitement. Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la dernère version de la page.Document créé le 30/01/2003, dernière modification le 26/10/2018
Source du document imprimé : https://www.gaudry.be/php-rf-pdostatement.fetchall.html
L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.
Références
Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.