Função PHP mysqli_stmt_store_result ()

Definição e Uso

A função mysqli_stmt_store_result () aceita um objeto de instrução como um parâmetro e armazena o conjunto de resultados da instrução fornecida localmente, se executar uma instrução SELECT, SHOW ou DESCRIBE.

Sintaxe

mysqli_stmt_store_result($stmt);

Parâmetros

Sr. Não Parâmetro e Descrição
1

stmt(Mandatory)

Este é um objeto que representa uma declaração preparada.

2

offset(Mandatory)

Este é um valor inteiro que representa a linha desejada (deve estar entre 0 e o número total de linhas no conjunto de resultados).

Valores Retornados

A função PHP mysqli_stmt_attr_get () retorna um valor booleano que é TRUE em caso de sucesso e FALSE em caso de falha.

Versão PHP

Esta função foi introduzida pela primeira vez no PHP Versão 5 e funciona em todas as versões posteriores.

Exemplo

O exemplo a seguir demonstra o uso da função mysqli_stmt_store_result () (no estilo procedural) -

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

   mysqli_query($con, "CREATE TABLE Test(Name VARCHAR(255), AGE INT)");
   mysqli_query($con, "insert into Test values('Raju', 25),('Rahman', 30),('Sarmista', 27)");
   print("Table Created.....\n");

   //Reading records
   $stmt = mysqli_prepare($con, "SELECT * FROM Test");

   //Executing the statement
   mysqli_stmt_execute($stmt);

   //Storing the result
   mysqli_stmt_store_result($stmt);

   //Number of rows
   $count = mysqli_stmt_num_rows($stmt);
   print("Number of rows in the table: ".$count."\n");

   //Closing the statement
   mysqli_stmt_close($stmt);

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

Isso produzirá o seguinte resultado -

Table Created.....
Number of rows in the table: 3

Exemplo

No estilo orientado a objetos, a sintaxe desta função é $ stmt-> store_result (); A seguir está o exemplo desta função no estilo orientado a objetos $ 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");

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

   //Storing the result
   $stmt->store_result();

   print("Number of rows ".$stmt ->num_rows);

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

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

Isso produzirá o seguinte resultado -

Table Created.....
Number of rows: 3