Heim > Datenbank > MySQL-Tutorial > Wie kann ich mehrere Funktionsauswertungen vermeiden, wenn ich „(func()).*' in PostgreSQL verwende?

Wie kann ich mehrere Funktionsauswertungen vermeiden, wenn ich „(func()).*' in PostgreSQL verwende?

DDD
Freigeben: 2025-01-10 11:19:42
Original
478 Leute haben es durchsucht

How Can I Avoid Multiple Function Evaluations When Using `(func()).*` in PostgreSQL?

*Vermeiden Sie die Verwendung von „(func()).“ in PostgreSQL, um wiederholte Funktionsaufrufe zu verursachen**

In PostgreSQL kann die Verwendung der (func()).*-Syntax für den Zugriff auf die Ergebnisse einer Funktion, die eine Tabelle oder einen zusammengesetzten Typ zurückgibt, zu wiederholten Aufrufen der Funktion für jede Spalte führen. Dies kann sich auf die Leistung auswirken, insbesondere wenn die Funktion rechenintensiv ist.

Lösung

Um dieses Problem zu vermeiden, können Sie den Funktionsaufruf wie folgt in eine Unterabfrage einschließen:

SELECT (mf).* FROM (
    SELECT my_func(x) AS mf FROM some_table
) sub;
Nach dem Login kopieren
Nach dem Login kopieren

Dadurch wird sichergestellt, dass die Funktion nur einmal aufgerufen wird, unabhängig davon, wie viele Spalten das Ergebnis enthält. Alternativ können Sie in PostgreSQL 9.3 und höher die LATERAL JOIN-Syntax verwenden:

SELECT mf.*
FROM some_table
LEFT JOIN LATERAL my_func(some_table.x) AS mf ON true;
Nach dem Login kopieren

Ursache des Problems

Der doppelte Aufruf von

erfolgt, weil der Parser (func()).* als Platzhalter für eine Liste von Spaltennamen behandelt. Es erweitert das Ausdrucksmakro in eine Reihe separater Spalten, was zu mehreren Aufrufen der Funktion führt.

Demo

Um das Problem und die Lösung zu demonstrieren, erstellen Sie eine Funktion:

CREATE OR REPLACE FUNCTION my_func(integer)
RETURNS TABLE(a integer, b integer, c integer) AS $$
BEGIN
    RAISE NOTICE 'my_func(%)',;
    RETURN QUERY SELECT , , ;
END;
$$ LANGUAGE plpgsql;
Nach dem Login kopieren

und eine Tabelle mit Dummy-Daten:

CREATE TABLE some_table AS SELECT x FROM generate_series(1,10) x;
Nach dem Login kopieren

Vergleichen Sie die Ergebnisse der folgenden Abfragen:

  • Originalsyntax:
SELECT (my_func(x)).* FROM some_table;
Nach dem Login kopieren
  • Lösungssyntax:
SELECT (mf).* FROM (
    SELECT my_func(x) AS mf FROM some_table
) sub;
Nach dem Login kopieren
Nach dem Login kopieren

Sie werden feststellen, dass die ursprüngliche Syntax mehrere Benachrichtigungen auslöst, während die Lösungssyntax nur eine Benachrichtigung auslöst, was den Effekt der Vermeidung mehrerer Funktionsaufrufe demonstriert.

Das obige ist der detaillierte Inhalt vonWie kann ich mehrere Funktionsauswertungen vermeiden, wenn ich „(func()).*' in PostgreSQL verwende?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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