Fonction PHP mysqli_stmt_attr_get ()

Définition et utilisation

Vous pouvez créer une instruction préparée, qui a des marqueurs de paramètre ("?") En cas de valeurs en utilisant la fonction mysqli_prepare (). Une fois que vous avez préparé une instruction, vous devez lier les valeurs aux paramètres de l'instruction créée à l'aide de la fonction mysqli_stmt_bind_param () .

Vous pouvez définir divers attributs pour l'instruction qui change son comportement en utilisant la fonction mysqli_stmt_attr_set ().

La fonction mysqli_stmt_attr_get () accepte un objet instruction et un attribut et renvoie la valeur actuelle de l'attribut donné.

Syntaxe

mysqli_stmt_attr_get($stmt, $attr);

Paramètres

Sr. Non Paramètre et description
1

stmt(Mandatory)

Il s'agit d'un objet représentant une instruction préparée.

2

attr(Mandatory)

Il s'agit d'une valeur entière représentant l'attribut que vous souhaitez définir pour l'instruction donnée qui peut être l'une des suivantes -

  • MYSQLI_STMT_ATTR_UPDATE_MAX_LENGTH

  • MYSQLI_STMT_ATTR_CURSOR_TYPE

  • MYSQLI_STMT_ATTR_PREFETCH_ROWS

Valeurs de retour

La fonction PHP mysqli_stmt_attr_get () retourne la valeur de l'attribut spécifié en cas de succès et false si l'attribut donné n'est pas trouvé.

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_stmt_attr_set () (dans le style procédural) -

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

   $query = "CREATE TABLE Test(Name VARCHAR(255), AGE INT)"; 
   mysqli_query($con, $query);
   print("Table Created.....\n");

   //insert into Test values('Raju', 25);
   $stmt = mysqli_prepare($con, "INSERT INTO Test values(?, ?)");
   mysqli_stmt_bind_param($stmt, "si", $Name, $Age);
   $Name = 'Raju';
   $Age = 25;
   print("Record Inserted.....\n");

   $res = mysqli_stmt_attr_set($stmt, MYSQLI_STMT_ATTR_UPDATE_MAX_LENGTH, TRUE);

   if($res){
      print("Successful.....\n");
   }else{
      print("Failed.....\n");
   }

   $val = mysqli_stmt_attr_get($stmt, MYSQLI_STMT_ATTR_UPDATE_MAX_LENGTH);
   print("Value: ".$val);

   //Executing the statement
   mysqli_stmt_execute($stmt);

   //Closing the statement
   mysqli_stmt_close($stmt);

   //Closing the connection
   mysqli_close($con);
?>

Cela produira le résultat suivant -

Table Created.....
Record Inserted.....
Successful.....
Value: 1

Exemple

Dans le style orienté objet, la syntaxe de cette fonction est $ stmt-> close (); Voici l'exemple de cette fonction dans le style orienté objet $ minus;

<?php
   //Creating a connection
   $con = new mysqli("localhost", "root", "password", "mydb");

   $query = "CREATE TABLE Test(Name VARCHAR(255), AGE INT)"; 
   $con -> query($query);
   print("Table Created.....\n");

   //insert into Test values('Raju', 25);//,('Rahman', 30),('Sarmista', 27)";
   $stmt = $con -> prepare( "INSERT INTO Test values(?, ?)");
   $stmt -> bind_param("si", $Name, $Age);
   $Name = 'Raju';
   $Age = 25;
   print("Record Inserted.....\n");

   //Setting the attribute
   $res= $stmt->attr_set(MYSQLI_STMT_ATTR_UPDATE_MAX_LENGTH, TRUE);

   if($res){
      print("Successful.....\n");
   }else{
      print("Failed.....\n");
   }

   $val = $stmt->attr_get(MYSQLI_STMT_ATTR_UPDATE_MAX_LENGTH);
   print("Value: ".$val);

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

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

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

Cela produira le résultat suivant -

Table Created.....
Record Inserted.....
Successful.....
Value: 1