PHP + MySql + Procédures stockées, comment accéder à une valeur « out » ?
-
09-06-2019 - |
Question
La documentation manque cruellement sur tout ce qui concerne les procédures stockées dans MySQL avec PHP.J'ai actuellement une procédure stockée que j'appelle via PHP, comment puis-je obtenir la valeur d'un paramètre out ?
La solution
il semble que la réponse soit trouvée dans ce post :
http://forums.mysql.com/read.php?52,198596,198717#msg-198717
Avec l'API PHP mysqli :
Supposons sproc myproc( IN i int, OUT j int ):
$mysqli = new mysqli( "HOST", "USR", "PWD", "DBNAME" );
$ivalue=1;
$res = $mysqli->multi_query( "CALL myproc($ivalue,@x);SELECT @x" );
if( $res ) {
$results = 0;
do {
if ($result = $mysqli->store_result()) {
printf( "<b>Result #%u</b>:<br/>", ++$results );
while( $row = $result->fetch_row() ) {
foreach( $row as $cell ) echo $cell, " ";
}
$result->close();
if( $mysqli->more_results() ) echo "<br/>";
}
} while( $mysqli->next_result() );
}
$mysqli->close();
Autres conseils
Voici un exemple de la façon de procéder avec mysql, mysqli et pdo :
http://www.joeyrivera.com/2009/using-mysql-stored-procedures-with-php-mysqlmysqlipdo/
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow