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

MySQL-Funktion für gespeicherte Prozeduren

PHPz
PHPzOriginal
2023-05-18 09:50:37661Durchsuche

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;

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;

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, ...);

Zum Beispiel:

CALL select_all_users();

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;

Zum Beispiel:

DROP PROCEDURE IF EXISTS select_all_users;

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;

Gespeicherte Prozedur aufrufen:

CALL double_num(5, @result);
SELECT @result;

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;

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;

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);

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;

Zum Beispiel:

DROP FUNCTION IF EXISTS double_num;

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;

Rufen Sie die Funktion auf:

SELECT factorial(5);

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!

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
Vorheriger Artikel:Welche Version von MySQLNächster Artikel:Welche Version von MySQL