Heim >Datenbank >MySQL-Tutorial >Detaillierte Einführung in die Rückgabewertproblematik gespeicherter MySQL-Prozeduren

Detaillierte Einführung in die Rückgabewertproblematik gespeicherter MySQL-Prozeduren

PHPz
PHPzOriginal
2023-04-19 14:11:211452Durchsuche

Bei der Datenentwicklung mit MySQL sind gespeicherte Prozeduren ein sehr häufig verwendetes Werkzeug. Gespeicherte Prozeduren können Coderedundanz reduzieren, Betriebsabläufe vereinfachen und die Effizienz des Codebetriebs verbessern, wodurch die Effizienz der Datenentwicklung erhöht wird. Bei der Verwendung gespeicherter Prozeduren müssen wir häufig den Rückgabewert der gespeicherten Prozedur berücksichtigen. In diesem Artikel wird das Rückgabewertproblem gespeicherter MySQL-Prozeduren ausführlich beschrieben.

1. Die Grundstruktur der gespeicherten MySQL-Prozedur

In MySQL besteht eine gespeicherte Prozedur aus den folgenden Teilen:

  1. Name der gespeicherten Prozedur: Die eindeutige Kennung der gespeicherten Prozedur in MySQL.
  2. Liste der gespeicherten Prozedurparameter: Wird zum Empfang externer eingehender Parameter zum Abschließen bestimmter Vorgänge verwendet.
  3. Hauptteil der gespeicherten Prozedur: Stellt die spezifische Ausführungslogik der gespeicherten Prozedur dar, die SQL-Anweisungen, bedingte Beurteilungen, Schleifenstrukturen usw. umfassen kann.
  4. Rückgabewert der gespeicherten Prozedur: Gibt den Wert an, der an den Aufrufer zurückgegeben wird, nachdem die Ausführung der gespeicherten Prozedur abgeschlossen ist.

2. Rückgabewerttypen gespeicherter MySQL-Prozeduren

In MySQL können die Rückgabewerttypen gespeicherter Prozeduren in die folgenden drei Typen unterteilt werden:

  1. Feste Anzahl von Rückgabewerten (OUT)

Dies Art des Rückgabewertes kann als der eindeutige Wert verstanden werden, der von der gespeicherten Prozedur zurückgegeben wird. Beim Definieren einer gespeicherten Prozedur können wir der Parameterliste Parameter vom Typ OUT hinzufügen, um Rückgabewerte zu erhalten. Zum Beispiel:

DELIMITER $$ CREATE PROCEDURE GetTotal(IN a INT, IN b INT, OUT total INT) BEGIN SET total = a + b; END$$ DELIMITER ;

Die gespeicherte Prozedur GetTotal empfängt zwei ganzzahlige Parameter a und b . Berechnen Sie die Summe der beiden Parameter und geben Sie das Ergebnis an den Aufrufer zurück.

Hinweis: Beim Definieren einer gespeicherten Prozedur sollte DELIMITER als andere Zeichen (andere Zeichen als Semikolon) definiert werden, um zu vermeiden, dass Semikolons in SQL-Anweisungen als Trennzeichen missverstanden werden.

  1. Mehrere Rückgabewerte (INOUT)

Diese Art von Rückgabewert kann als gespeicherte Prozedur verstanden werden, die mehrere Werte zurückgibt (einschließlich Eingabeparameter und Ausgabeparameter). Beim Definieren einer gespeicherten Prozedur können wir Parameter vom Typ INOUT zur Parameterliste hinzufügen. Zum Beispiel:

DELIMITER $$ CREATE PROCEDURE CompareAge(INOUT age1 INT, INOUT age2 INT) BEGIN IF age1 < age2 THEN SET age1 = age1; END$$ DELIMITER ;

Stored procedure CompareAge , Empfangen Sie zwei ganzzahlige Parameter Alter1 und Alter2, vergleichen Sie die Größe der beiden Parameter. Wenn Alter1 kleiner als Alter2 ist, tauschen Sie die Werte der beiden Parameter aus.

Beim Ausführen einer gespeicherten Prozedur müssen wir zunächst die Anfangswerte für die Parameter festlegen und dann die Parameter an die gespeicherte Prozedur übergeben. Nachdem die gespeicherte Prozedur ausgeführt wurde, können die Ergebnisse auf die ursprünglichen Parameter aktualisiert werden.

  1. Ergebnismenge zurückgeben (CURSOR)

Diese Art von Rückgabewert kann als Rückgabe einer Ergebnismenge verstanden werden. Beim Definieren einer gespeicherten Prozedur müssen Sie einen Cursor definieren und diesen verwenden, um die Ergebnismenge zurückzugeben. Zum Beispiel:

DELIMITER $$ CREATE PROCEDURE GetList() BEGIN DECLARE cur CURSOR FOR SELECT * FROM TABLE_NAME; OPEN cur; END$$ DELIMITER ;

Stored procedure GetList, Abfrage der Datensätze von TABLE_NAME Tabelle und gibt die Ergebnismenge an den Aufrufer zurück.

Hinweis: Wenn Sie die Ergebnismenge verwenden, sollten Sie die CALL-Anweisung verwenden, um die gespeicherte Prozedur aufzurufen, z. B.: CALL GetList().

3. Ausführung gespeicherter MySQL-Prozeduren

Die Ausführung gespeicherter Prozeduren ist in zwei Phasen unterteilt: die Kompilierungsphase der gespeicherten Prozedur und die Ausführungsphase der gespeicherten Prozedur.

  1. Die Kompilierungsphase gespeicherter Prozeduren

Die Kompilierungsphase gespeicherter Prozeduren bedeutet, dass MySQL die gespeicherte Prozedur kompiliert, wenn es sie zum ersten Mal abruft. Während des Kompilierungsprozesses führt MySQL eine Syntaxanalyse und eine semantische Analyse der gespeicherten Prozedur durch und generiert einen Ausführungsplan.

  1. Die Ausführungsphase der gespeicherten Prozedur

Die Ausführungsphase der gespeicherten Prozedur bezieht sich darauf, dass MySQL beim Aufruf der gespeicherten Prozedur den generierten Ausführungsplan ausführt und die Ausführungsergebnisse an den Aufrufer zurückgibt. Während des Ausführungsprozesses führt MySQL zunächst die Anweisung des Hauptteils der gespeicherten Prozedur aus und gibt dann das entsprechende Ergebnis entsprechend dem Rückgabewerttyp der gespeicherten Prozedur zurück.

4. Verwendung von MySQL-Rückgabewerten für gespeicherte Prozeduren

Bei Verwendung des Rückgabewerts einer gespeicherten Prozedur müssen wir die CALL-Anweisung verwenden, um die gespeicherte Prozedur aufzurufen und die Parameter an die gespeicherte Prozedur zu übergeben. Zum Beispiel:

CALL GetTotal(1, 2, @result); SELECT @result;

Nachdem wir die gespeicherte Prozedur ausgeführt haben, können wir den Rückgabewert der gespeicherten Prozedur über den @-Variablennamen abrufen. @result ist hier der Rückgabewert der gespeicherten Prozedur GetTotal.

Hinweis: Wenn Sie eine gespeicherte Prozedur verwenden, um eine Ergebnismenge zurückzugeben, sollten Sie die CALL-Anweisung zum Aufrufen der gespeicherten Prozedur verwenden und einen Cursor verwenden, um die Ergebnismenge zu verarbeiten.

5. Zusammenfassung

In diesem Artikel wird das Rückgabewertproblem von gespeicherten MySQL-Prozeduren ausführlich vorgestellt, einschließlich der Grundstruktur gespeicherter Prozeduren, Rückgabewerttypen, Ausführungsprozessen und der Verwendung von Rückgabewerten. Bei der Verwendung gespeicherter Prozeduren sollten wir den geeigneten Rückgabewerttyp entsprechend den tatsächlichen Anforderungen auswählen und die CALL-Anweisung zum Aufrufen der gespeicherten Prozedur verwenden, um eine hohe Effizienz bei der Datenentwicklung zu erreichen.

Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in die Rückgabewertproblematik gespeicherter MySQL-Prozeduren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn