Maison > base de données > tutoriel mysql > Comment attribuer le résultat d'une requête dynamique à un paramètre OUT dans une procédure stockée MySQL ?

Comment attribuer le résultat d'une requête dynamique à un paramètre OUT dans une procédure stockée MySQL ?

Linda Hamilton
Libérer: 2024-12-30 06:41:10
original
995 Les gens l'ont consulté

How to Assign the Result of a Dynamic Query to an OUT Parameter in a MySQL Stored Procedure?

Exécution dynamique de requêtes et affectation de sortie dans une procédure stockée MySQL

Dans MySQL, il est possible de générer et d'exécuter dynamiquement des requêtes dans une procédure stockée . Cependant, pour attribuer le résultat d'une requête dynamique à un paramètre OUT, une approche légèrement différente est nécessaire.

Considérez le code de procédure stockée fourni dans la question :

CREATE PROCEDURE 'searchInvoice'
(
  OUT numOfRecords INT
)
BEGIN
  DECLARE query1 TEXT; 
  DECLARE query2 TEXT; 

 SET query1 = 'SELECT COUNT(*) bla bla bla.....'; 
 // Query1 to select the count of matching tuples..

 SET query2 = 'SELECT * from bla bla bla....';
 // Query2 to select original records...

 // later part of this both queries generate dynamically according to some IN parameters..

 // now I wanna assign the output of the query1 into numOfRecords 
 // and I wanna execute the query2 as well.. like this

    SET @Sql = query2;        
    PREPARE STMT FROM @Sql; 
    EXECUTE STMT; 
    DEALLOCATE PREPARE STMT;

 // output of the query2 can be read in PHP

END
Copier après la connexion

Pour attribuer le sortie de query1 au paramètre numOfRecords OUT, les étapes suivantes peuvent être suivies :

  1. Créer des variables définies par l'utilisateur pour stocker le résultats :
SET @numOfRecords = 0;
Copier après la connexion
  1. Préparer et exécuter la requête dynamique à l'aide d'un curseur :
DECLARE query1Cursor CURSOR FOR query1;
OPEN query1Cursor;
FETCH query1Cursor INTO @numOfRecords;
CLOSE query1Cursor;
Copier après la connexion
  1. Mettre à jour le paramètre OUT avec la valeur attribuée :
SET numOfRecords = @numOfRecords;
Copier après la connexion

Avec cette approche modifiée, la procédure stockée peut à la fois exécuter des requêtes dynamiques et attribuer la sortie de requêtes spécifiques requêtes vers les paramètres OUT.

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal