Fonction PHP mysqli_fetch_lengths ()

Définition et utilisation

Un objet résultat PHP (de la classe mysqli_result) représente le résultat MySQL, retourné par les requêtes SELECT ou, DESCRIBE ou, EXPLAIN.

La fonction mysqli_fetch_lengths () accepte un objet résultat en tant que paramètre, récupère les longueurs des colonnes dans la ligne courante du résultat donné et les renvoie sous la forme d'un tableau.

Syntaxe

mysqli_fetch_lengths($result);

Paramètres

Sr.Non Paramètre et description
1

result(Mandatory)

Il s'agit d'un identifiant représentant un objet de résultat.

Valeurs de retour

La fonction PHP mysqli_fetch_lengths () retourne un tableau (d'entiers) contenant la longueur / taille de chaque colonne (de la ligne courante), en cas de succès et, elle renvoie la valeur booléenne FALSE en cas d'erreur.

Version PHP

Cette fonction a été introduite pour la première fois dans la version 5 de PHP et fonctionne dans toutes les versions ultérieures.

Exemple

L'exemple suivant montre l'utilisation de la fonction mysqli_fetch_lengths () (dans un style procédural) -

<?php
   $con = mysqli_connect("localhost", "root", "password", "mydb");

   mysqli_query($con, "CREATE TABLE myplayers(ID INT, First_Name VARCHAR(255), Last_Name VARCHAR(255), Place_Of_Birth VARCHAR(255), Country VARCHAR(255))");
   print("Table Created.....\n");
   mysqli_query($con, "INSERT INTO myplayers values(1, 'Sikhar', 'Dhawan', 'Delhi', 'India')");
   mysqli_query($con, "INSERT INTO myplayers values(2, 'Jonathan', 'Trott', 'CapeTown', 'SouthAfrica')");
   mysqli_query($con, "INSERT INTO myplayers values(3, 'Kumara', 'Sangakkara', 'Matale', 'Srilanka')");
   print("Record Inserted.....\n");

   //Retrieving the contents of the table
   $res = mysqli_query($con, "SELECT * FROM myplayers");

   //Lengths of the rows
   $row = mysqli_fetch_row($res);
   $lengths = mysqli_fetch_lengths($res);

   print_r($lengths);
   mysqli_free_result($res);

   mysqli_close($con);
?>

Cela produira le résultat suivant -

Table Created.....
Record Inserted.....
Array
(
    [0] => 1
    [1] => 6
    [2] => 6
    [3] => 5
    [4] => 5
)

Exemple

Dans le style orienté objet, la syntaxe de cette fonction est $ result-> lengths; Voici l'exemple de cette fonction dans le style orienté objet $ minus;

<?php
   //Creating a connection
   $con = new mysqli("localhost", "root", "password", "mydb");
  
   $con -> query("CREATE TABLE Test(Name VARCHAR(255), AGE INT)");
   $con -> query("insert into Test values('Raju', 25),('Rahman', 30),('Sarmista', 27)");
   print("Table Created.....\n");

   $stmt = $con -> prepare( "SELECT * FROM Test WHERE Name in(?, ?)");
   $stmt -> bind_param("ss", $name1, $name2);
   $name1 = 'Raju';
   $name2 = 'Rahman';

   //Executing the statement
   $stmt->execute();

   //Retrieving the result
   $res = $stmt->get_result();
   $row = $res->fetch_row();

   $len = $res ->lengths;
   print_r($len);

   //Closing the statement
   $stmt->close();

   //Closing the connection
   $con->close();
?>

Cela produira le résultat suivant -

Table Created.....
Array
(
    [0] => 4
    [1] => 0
)

Exemple

Pour que cette fonction récupère les longueurs, il est obligatoire de l'appeler après avoir récupéré les lignes à l'aide des méthodes mysqli_fetch_row / array / object sinon, elle retourne false $ moins;

<?php
   $con = mysqli_connect("localhost", "root", "password", "mydb");

   mysqli_query($con, "CREATE TABLE data(ID INT, Name VARCHAR(255), Age INT)");
   mysqli_query($con, "INSERT INTO data values(1, 'Mohan', 25)");
   mysqli_query($con, "INSERT INTO data values(2, 'Syamala', 36)");
   print("Record Inserted.....\n");

   //Retrieving the contents of the table
   $res = mysqli_query($con, "SELECT * FROM data");

   //Lengths of the rows
   $bool = $lengths = mysqli_fetch_lengths($res);

   if($bool){
      print("Lengths Retrieved");
   }else{
      print("Failed");
   }

   print_r($lengths);
   mysqli_free_result($res);

   mysqli_close($con);
?>

Cela produira le résultat suivant -

Record Inserted.....
Failed