Heim > Datenbank > MySQL-Tutorial > MySQL-Funktion für gespeicherte Prozeduren

MySQL-Funktion für gespeicherte Prozeduren

PHPz
Freigeben: 2023-05-18 09:50:37
Original
705 Leute haben es durchsucht

MySQL ist ein gängiges Datenbankverwaltungssystem mit den Funktionen gespeicherter Prozeduren und Funktionen. In diesem Artikel werden die Konzepte, Verwendung und Beispiele gespeicherter Prozeduren und Funktionen in MySQL vorgestellt.

1. Gespeicherte Prozedur

  1. Konzept

Eine gespeicherte Prozedur ist ein Satz vorkompilierter SQL-Anweisungen, die in der Datenbank gespeichert und wiederholt ausgeführt werden können. Es wird häufig verwendet, um komplexe Datenbankoperationen wie das Einfügen, Aktualisieren, Löschen von Daten usw. durchzuführen. Gespeicherte Prozeduren können Parameter empfangen und eine oder mehrere Ergebnismengen zurückgeben.

  1. Erstellen Sie eine gespeicherte Prozedur.

Verwenden Sie die CREATE PROCEDURE-Anweisung, um eine gespeicherte Prozedur zu erstellen. Die Syntax lautet wie folgt:

CREATE PROCEDURE procedure_name ([IN | OUT | INOUT] parameter_name datatype [(size)]) [NOT DETERMINISTIC] [SQL SECURITY {DEFINER | INVOKER}] [COMMENT ‘string’]
BEGIN
-- 存储过程内部语句
END;
Nach dem Login kopieren

Unter diesen sind die Parameter optional: IN stellt Eingabeparameter dar, OUT stellt Ausgabeparameter dar und INOUT repräsentiert sowohl Eingabeparameter als auch Ausgabeparameter. Datentyp stellt den Datentyp dar, Größe stellt die Länge dar, NOT DETERMINISTIC stellt Determinismus dar, SQL SECURITY stellt die Zugriffskontrollebene dar, COMMENT stellt den Kommentar zwischen BEGIN und END dar und ist der Satz von SQL-Anweisungen innerhalb der gespeicherten Prozedur.

Zum Beispiel:

CREATE PROCEDURE select_all_users ()
BEGIN
SELECT * FROM users;
END;
Nach dem Login kopieren

Die gespeicherte Prozedur heißt „select_all_users“, hat keine Parameter und führt intern die SELECT * FROM-Benutzeranweisung aus, die alle Daten in der Benutzertabelle abfragt.

  1. Eine gespeicherte Prozedur aufrufen

Eine gespeicherte Prozedur mit der CALL-Anweisung aufrufen. Die Syntax lautet wie folgt:

CALL procedure_name(param1, param2, ...);
Nach dem Login kopieren

Zum Beispiel:

CALL select_all_users();
Nach dem Login kopieren

Diese Anweisung führt die zuvor erstellte gespeicherte Prozedur „select_all_users“ aus.

  1. Eine gespeicherte Prozedur löschen

Verwenden Sie die DROP PROCEDURE-Anweisung, um eine gespeicherte Prozedur zu löschen. Die Syntax lautet wie folgt:

DROP PROCEDURE IF EXISTS procedure_name;
Nach dem Login kopieren

Zum Beispiel:

DROP PROCEDURE IF EXISTS select_all_users;
Nach dem Login kopieren

Diese Anweisung löscht die gespeicherte Prozedur namens select_all_users.

  1. Beispiel für eine gespeicherte Prozedur

Das Folgende ist ein einfaches Beispiel für eine gespeicherte Prozedur, die einen Eingabeparameter empfängt, den Parameter mit 2 multipliziert und ausgibt:

CREATE PROCEDURE double_num (IN num INT, OUT result INT)
BEGIN
SET result = num * 2;
END;
Nach dem Login kopieren

Gespeicherte Prozedur aufrufen:

CALL double_num(5, @result);
SELECT @result;
Nach dem Login kopieren

Das Ausgabeergebnis ist 10.

2. Funktionskonzept

Eine Funktion ist eine spezielle gespeicherte Prozedur, die einen Wert zurückgibt und null oder mehr Eingabeparameter empfangen kann. Im Gegensatz zu gespeicherten Prozeduren können Funktionen keine Datendefinitionsanweisungen (CREATE, ALTER, DROP) oder Transaktionssteuerungsanweisungen (COMMIT, ROLLBACK) ausführen.

  1. Erstellen Sie eine Funktion

Verwenden Sie die CREATE FUNCTION-Anweisung, um eine Funktion zu erstellen. Die Syntax lautet wie folgt:

CREATE FUNCTION function_name ([parameter_name datatype [(size)]] [, ...]) RETURNS return_datatype
BEGIN
-- 函数内部语句
END;
Nach dem Login kopieren

Dabei stellen Parametername und Datentyp den Namen und Typ des Eingabeparameters dar, Größe stellt die Länge dar; stellt den Datentyp des Rückgabewerts dar; zwischen BEGIN und END befindet sich der Satz von SQL-Anweisungen innerhalb der gespeicherten Prozedur.

Zum Beispiel:

CREATE FUNCTION double_num (num INT) RETURNS INT
BEGIN
RETURN num * 2;
END;
Nach dem Login kopieren

Die Funktion heißt double_num, der Eingabeparameter ist num, der Rückgabetyp ist INT und der num-Wert wird mit 2 multipliziert und zurückgegeben.

  1. Rufen Sie die Funktion auf

Rufen Sie die Funktion mit der SELECT-Anweisung auf und fragen Sie das Ergebnis ab:

SELECT double_num(5);
Nach dem Login kopieren

Das Ausgabeergebnis ist 10.

  1. Funktion löschen

Verwenden Sie die DROP FUNCTION-Anweisung, um eine Funktion zu löschen. Die Syntax lautet wie folgt:

DROP FUNCTION IF EXISTS function_name;
Nach dem Login kopieren

Zum Beispiel:

DROP FUNCTION IF EXISTS double_num;
Nach dem Login kopieren

Diese Anweisung löscht die Funktion mit dem Namen double_num.

  1. Funktionsbeispiel

Hier ist ein einfaches Funktionsbeispiel, das die Fakultät einer Zahl findet:

CREATE FUNCTION factorial (n INT) RETURNS INT
BEGIN
IF n <= 0 THEN
RETURN 1;
ELSE
RETURN n * factorial(n - 1);
END IF;
END;
Nach dem Login kopieren

Rufen Sie die Funktion auf:

SELECT factorial(5);
Nach dem Login kopieren

Das Ausgabeergebnis ist 120.

3. Der Unterschied zwischen gespeicherten Prozeduren und Funktionen

Die Hauptunterschiede zwischen gespeicherten Prozeduren und Funktionen sind:

  1. Verschiedene Rückgabetypen: Gespeicherte Prozeduren müssen keine Werte zurückgeben, Funktionen hingegen schon.
  2. Verschiedene Verarbeitungsmethoden: Gespeicherte Prozeduren werden normalerweise zum Ausführen einiger Vorgänge wie Einfügen, Aktualisieren, Löschen usw. verwendet. Funktionen werden häufig für mathematische Berechnungen und Zeichenfolgenverarbeitung verwendet.
  3. Verschiedene Parameterübergabemethoden: Gespeicherte Prozeduren können IN-, OUT- und INOUT-Parameterübergabemethoden verwenden. Funktionen erlauben nur die IN-Parameterübergabemethode.
  4. Die Aufrufmethoden sind unterschiedlich: Gespeicherte Prozeduren werden mit der CALL-Anweisung aufgerufen; Funktionen können in den SELECT-, WHERE- und HAVING-Klauseln aufgerufen werden.

4. Zusammenfassung

Dieser Artikel stellt die Konzepte, Verwendung und Beispiele gespeicherter Prozeduren und Funktionen in MySQL vor. Gespeicherte Prozeduren und Funktionen sind wichtige Werkzeuge für die Datenbankverwaltung und können die Effizienz und Sicherheit der Datenbank verbessern. In der tatsächlichen Entwicklung sollten gespeicherte Prozeduren oder Funktionen entsprechend den spezifischen Anforderungen ausgewählt werden.

Das obige ist der detaillierte Inhalt vonMySQL-Funktion für gespeicherte Prozeduren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage