Maison >développement back-end >tutoriel php >Comment appeler des procédures stockées MySQL depuis PHP ?

Comment appeler des procédures stockées MySQL depuis PHP ?

Barbara Streisand
Barbara Streisandoriginal
2024-11-06 19:49:02456parcourir

How to Call MySQL Stored Procedures from PHP?

Appel de procédures stockées MySQL depuis PHP

Lorsque vous travaillez avec une base de données, les procédures stockées offrent un moyen structuré et encapsulé d'exécuter des opérations répétitives de base de données. Si vous souhaitez intégrer cette fonctionnalité dans votre application PHP, vous pouvez exploiter l'extension mysqli, qui prend en charge l'appel de procédures stockées dans les bases de données MySQL.

Exemple :

Considérez le scénario suivant :

  • Version du client MySQL : 4.1.11
  • Version du serveur MySQL : 5.0.45

Vous disposez d'une procédure stockée nommée getTreeNodeName qui prend un paramètre nid et renvoie le nom du nœud correspondant. Vous trouverez ci-dessous le code PHP que vous pouvez utiliser pour appeler cette procédure stockée :

<?php

// Enable error reporting
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);

// Connect to the MySQL database
$connection = mysqli_connect("hostname", "user", "password", "db", "port");

// Create a prepared statement for the stored procedure
$stmt = mysqli_prepare($connection, "CALL getTreeNodeName(?)");

// Bind the parameter to the statement
mysqli_stmt_bind_param($stmt, "i", $nid);

// Execute the prepared statement
mysqli_stmt_execute($stmt);

// Bind the result to variables
mysqli_stmt_bind_result($stmt, $nodeName);

// Fetch the result
mysqli_stmt_fetch($stmt);

// Print the result
echo $nodeName;

// Close the prepared statement and connection
mysqli_stmt_close($stmt);
mysqli_close($connection);

?>

Remarque :

Si vous rencontrez des problèmes lors de l'utilisation des fonctions mysql_connect, mysql_query et mysql_fetch_array , envisagez plutôt d'utiliser l'extension mysqli, qui offre une sécurité et des performances améliorées.

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn