Função PHP mysqli_stmt_errno ()

Definição e Uso

o mysqli_stmt_errno() função retorna o código do erro ocorrido durante a execução da última instrução.

Sintaxe

mysqli_stmt_errno($stmt)

Parâmetros

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

stmt(Mandatory)

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

Valores Retornados

A função PHP mysqli_stmt_errno () retorna um valor inteiro que representa o código do erro da execução da última instrução. Se não houver erros, esta função retorna 0 .

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_errno () (no estilo procedural) -

<?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')");
   print("Record Inserted.....\n");

   $stmt = mysqli_prepare($con, "SELECT * FROM myplayers");

   mysqli_query($con, "DROP TABLE myplayers");

   //Executing the statement
   mysqli_stmt_execute($stmt);

   //Error Code
   $code = mysqli_stmt_errno($stmt);
   print("Error Code: ".$code);

   //Closing the statement
   mysqli_stmt_close($stmt);

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

Isso produzirá o seguinte resultado -

Table Created.....
Record Inserted.....
Error Code: 1146

Exemplo

No estilo orientado a objetos, a sintaxe desta função é $ stmt -> errno . A seguir está o exemplo desta função no estilo orientado a objetos -

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

   $con -> query("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");
   $con -> query("INSERT INTO myplayers values(1, 'Sikhar', 'Dhawan', 'Delhi', 'India')");
   print("Record Inserted.....\n");

   $stmt = $con ->prepare("SELECT * FROM myplayers");

   $con ->query("DROP TABLE myplayers");

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

   //Error Code
   $code = $stmt ->errno;
   print("error Code: ".$code);

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

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

?>

Isso produzirá o seguinte resultado -

Table Created.....
Record Inserted.....
error Code: 1146

Exemplo

Se não houver erros no último objeto de instrução executado, esta função retorna 0 -

<?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");

   query = "INSERT INTO myplayers values(1, 'Sikhar', 'Dhawan', 'Delhi', 'India'),(2, 'Jonathan', 'Trott', 'CapeTown', 'SouthAfrica'),(3, 'Kumara', 'Sangakkara', 'Matale', 'Srilanka')";

   //Preparing a statement
   $stmt = mysqli_prepare($con, $query);

   //Executing the statement
   mysqli_stmt_execute($stmt);
   print("Record Inserted.....\n");


   //Error Code
   $code = mysqli_stmt_errno($stmt);
   print("Error Code: ".$code);

   //Closing the statement
   mysqli_stmt_close($stmt);

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

Isso produzirá o seguinte resultado -

Table Created.....
Record Inserted.....
Error Code: 0