Maison > développement back-end > tutoriel php > Explication détaillée de la méthode fetchAll() pour obtenir des jeux de résultats dans PDO

Explication détaillée de la méthode fetchAll() pour obtenir des jeux de résultats dans PDO

黄舟
Libérer: 2023-03-07 17:24:01
original
21865 Les gens l'ont consulté

Explication détaillée de la méthode fetchAll() pour obtenir l'ensemble de résultats dans PDO

La méthode fetchAll() obtient toutes les lignes de l'ensemble de résultats et renvoie une liste contenant toutes les lignes du jeu de résultats. Tableau binaire de lignes !

Ensuite, dans l'article précédent "Explication détaillée de la méthode fetch() pour obtenir des ensembles de résultats dans PDO", nous avons introduit la méthode fetch() pour obtenir l'ensemble de résultats. la méthode fetchAll() est similaire à la méthode précédente fetch(), mais cette méthode ne doit être appelée qu'une seule fois pour obtenir toutes les lignes du jeu de résultats et les affecter au tableau renvoyé (bidimensionnel).

Le format de syntaxe de la méthode fetchAll() est le suivant :

array PDOStatement::fetchAll ([ int $fetch_style [, mixed $fetch_argument [, array $ctor_args = array() ]]] )
Copier après la connexion

Paramètre fetch_style : contrôle la méthode de retour des données dans l'ensemble de résultats. Les valeurs facultatives sont les suivantes. :

说 明
PDO::FETCH_ASSOC关联数组形式
PDO::FETCH_NUM数字索引数组形式
PDO::FETCH_BOTH两者数组形式都有,这是默认的
PDO::FETCH_OBJ按照对象的形式,类似于以前的mysql_fetch_object()
PDO::FETCH_BOUND以布尔值的形式返回结果,同时将获取的列值赋给bindParam()方法中指定的变量
PDO::FETCH_LAZY以关联数组、数字索引数组和对象3种形式返回结果。

Paramètre column_index : l'index du champ !

La valeur de retour est un tableau à deux dimensions contenant toutes les données de l'ensemble de résultats.

Ci-dessous, nous utilisons la méthode fetchAll() pour obtenir toutes les lignes de l'ensemble de résultats et lisons les données dans le tableau bidimensionnel via l'instruction for pour terminer la sortie en boucle des données dans la base de données. Les étapes spécifiques sont les suivantes :

Créez d'abord un fichier php, connectez-vous à la base de données MySQL via PDO, puis définissez l'instruction de requête SELECT, appliquez les méthodes préparer() et exécuter() pour effectuer l'opération de requête, puis renvoyez toutes les lignes de l'ensemble de résultats via la méthode fetchAll(), et enfin utilisez l'instruction for pour terminer la sortie en boucle de toutes les données de l'ensemble de résultats, le code est le suivant :

<?php
header("Content-Type:text/html; charset=utf-8");    //设置页面的编码格式
$dbms = "mysql";                                  // 数据库的类型
$dbName ="php_cn";                                //使用的数据库名称
$user = "root";                                   //使用的数据库用户名
$pwd = "root";                                    //使用的数据库密码
$host = "localhost";                              //使用的主机名称
$dsn  = "$dbms:host=$host;dbname=$dbName";
try{
    $pdo=new PDO($dsn,$user,$pwd);//初始化一个PDO对象,就是创建了数据库连接对象$pdo
    $query="select * from user";//需要执行的sql语句
    $res=$pdo->prepare($query);//准备查询语句
    $res->execute();            //执行查询语句,并返回结果集
    ?>
    <table border="1" width="500">
        <tr>
            <td height="22" align="center" valign="middle">id</td>
            <td height="22" align="center" valign="middle">用户名</td>
            <td height="22" align="center" valign="middle">密码</td>
        </tr>
        <?php
  $result=$res->fetchAll(PDO::FETCH_ASSOC) ;        // 获取结果集中的所有数据。
        for ($i=0;$i<count($result);$i++){          //循环读取二维数组中的数据。
        ?>
        <tr>
        <td height="22" align="center" valign="middle"><?php echo $result[$i][&#39;id&#39;];?></td>
        <td height="22" align="center" valign="middle"><?php echo $result[$i][&#39;username&#39;];?></td>
        <td height="22" align="center" valign="middle"><?php echo $result[$i][&#39;password&#39;];?></td>
        </tr>
<?php
    }
}catch(Exception $e){
    die("Error!:".$e->getMessage().&#39;<br>&#39;);
}
?>
</table>
Copier après la connexion

La sortie Le résultat est le suivant :

Explication détaillée de la méthode fetchAll() pour obtenir des jeux de résultats dans PDO

À propos de fetchAll() pour obtenir l'ensemble de résultats dans PDO Nous présenterons d'abord la méthode ici. Cette méthode est similaire à la méthode fetch() que nous avons. introduit précédemment. Ne l'utilisez pas à tort. Dans le prochain article, nous présenterons la troisième méthode pour obtenir l'ensemble de résultats dans PDO, la méthode fetchColumn (), veuillez lire " Explication détaillée de la méthode fetchColumn() pour. obtention d'ensembles de résultats dans PDO " pour plus de détails !

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!

Étiquettes associées:
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal