Maison >développement back-end >tutoriel php >Explication détaillée des fonctions de la série mysql_fetch en PHP
Cet article présente principalement le tutoriel d'utilisation courante de la fonction mysql_fetch en PHP pour faire fonctionner MySQL. L'article mentionne l'utilisation des fonctions fetch_array, mysql_fetch_row et mysql_fetch_object. J'espère que cela aide tout le monde.
fonction de colonne mysql_fetch_*
mysql_fetch_* La fonction principale de la fonction de colonne est d'obtenir des résultats de requête pertinents à partir de l'ensemble de résultats renvoyé par la requête, comprenant principalement :
mysql_fetch_array() : récupère une ligne de l'ensemble de résultats sous forme de tableau associatif ou de tableau d'index, ou les deux.
mysql_fetch_row() : récupère une ligne du jeu de résultats sous forme de tableau d'énumération
mysql_fetch_assoc() : récupère une ligne de l'ensemble de résultats sous forme de tableau associatif
mysql_fetch_object() : récupère une ligne de l'ensemble de résultats en tant qu'objet
mysql_fetch_field() : obtient les informations de champ à partir de l'ensemble de résultats et les renvoie en tant qu'objet
mysql_fetch_lengths() : Obtenez une ligne de chaque sortie de contenu de champ dans l'ensemble de résultats Longueur
mysql_fetch_array()
La fonction mysql_fetch_array() est utilisé pour obtenir une ligne de l'ensemble de résultats sous forme de tableau associatif ou de tableau d'index, ou les deux. Renvoie un tableau en cas de succès, FALSE sinon.
Syntaxe :
array mysql_fetch_array( resource result [, int result_type] )
Description du paramètre :
result : la ressource de l'ensemble de données renvoyée par la fonction de requête (telle que mysql_query)
result_type : constante facultative, indiquant le type de résultat du tableau, les valeurs acceptables sont les suivantes :
MYSQL_BOTH : Par défaut, obtenez un tableau contenant à la fois des index associatifs et numériques, en utilisant le nom du champ comme nom de clé
MYSQL_ASSOC : Obtenez uniquement le tableau d'index associatifs
MYSQL_NUM : Obtenez uniquement les tableaux indexés numériquement
Exemple 1, en utilisant MYSQL_NUM :
<?php $conn = @mysql_connect("localhost","root","root123"); if (!$conn){ die("连接数据库失败:" . mysql_error()); } mysql_select_db("test", $conn); mysql_query("set character set 'gbk'"); $result = mysql_query("SELECT uid,username FROM user"); while($row = mysql_fetch_array($result, MYSQL_NUM)){ echo "用户ID:".$row[0]."<br />"; echo "用户名:".$row[1]."<br />"; } ?>
Sortie du navigateur :
用户ID:1 用户名:admin 用户ID:2 用户名:小明 用户ID:3 用户名:Jack 用户ID:4 用户名:小王
Exemple 2, utilisez MYSQL_ ASSOC :
//重复代码省略 $result = mysql_query("SELECT uid,username FROM user"); while($row = mysql_fetch_array($result, MYSQL_ ASSOC)){ echo "用户ID:".$row['uid']."<br />"; echo "用户名:".$row['username']."<br />"; }
Le contenu de sortie du navigateur est le même que ci-dessus.
Lors de l'utilisation de MYSQL_BOTH ou de l'omission de ce paramètre, il aura les caractéristiques à la fois de MYSQL_NUM et de MYSQL_ ASSOC.
Remarque
Les noms de champs renvoyés par cette fonction en tant que clés de tableau sont sensibles à la casse
L'utilisation de mysql_fetch_array() n'est pas significativement plus lente que l'utilisation de mysql_fetch_row(), et elle fournit également beaucoup plus de valeurs
Cette fonction n'obtient qu'une seule ligne de données à partir du pointeur de données actuel et la renvoie en conséquence. S'il est exécuté une fois, le pointeur de données pointera vers la colonne de données suivante
Si vous souhaitez obtenir plusieurs lignes ou toutes les données, vous devez le faire. utilisez une structure de boucle pour extraire les données ligne par ligne
Si deux colonnes ou plus du résultat ont le même nom de champ, la dernière colonne aura priorité. Pour accéder aux autres colonnes du même nom, vous devez utiliser l'index numérique de la colonne ou donner un alias à la colonne
mysql_fetch_row()
Opération MySQL de PHP function mysql_fetch_row() Utilisé pour obtenir une ligne du jeu de résultats sous forme de tableau d'énumération. Renvoie un tableau en cas de succès, FALSE sinon.
Syntaxe :
array mysql_fetch_row( resource result )
Les performances de cette fonction sont cohérentes avec mysql_fetch_array (résultat de la ressource, MYSQL_NUM) , veuillez vous référer à L'utilisation de la fonction mysql_fetch_array() ne sera pas décrite en détail ici.
mysql_fetch_object()
Opération PHP La fonction MySQL mysql_fetch_object() est utilisée pour obtenir une ligne en tant qu'objet à partir de l'ensemble de résultats. Elle renvoie un objet avec succès, sinon elle renvoie FALSE.
Syntaxe :
object mysql_fetch_object( resource result )
Exemple :
<?php $conn = @mysql_connect("localhost","root","root123"); if (!$conn){ die("连接数据库失败:" . mysql_error()); } mysql_select_db("test", $conn); mysql_query("set character set 'gbk'"); $result = mysql_query("SELECT uid,username FROM user"); while($row = mysql_fetch_object($result)){ echo "用户ID:".$row->uid."<br />"; echo "用户名:".$row->username."<br />"; } ?>
Sortie du navigateur :
用户ID:1 用户名:admin 用户ID:2 用户名:小明 用户ID:3 用户名:Jack 用户ID:4 用户名:小王
Recommandations associées :
La classe de base de données PHP convient au service MySQL SQL
Base de données PHP Utiliser mysqli
Boîte à outils de base de données PHP ultra-légère
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!