PostgreSQL parametrisierte Order By/Limit in Tabellenfunktion
Die Frage untersucht Optionen für die Einbindung von Order by- und Limit-Klauseln in eine PostgreSQL-Tabellenfunktion. Dies hebt die potenzielle Ineffizienz des Bestellens und Schneidens außerhalb der Funktion hervor.
Eine vorgestellte Lösung ist die Verwendung von a plpgsql-Funktion, die eine komplexere Abfragekonstruktion und -ausführung über EXECUTE ermöglicht. Dieser Ansatz bietet eine größere Flexibilität und Kontrolle über die Abfrage.
Um dies zu implementieren, kann eine modifizierte plpgsql-Funktion erstellt werden:
CREATE OR REPLACE FUNCTION get_stuff(_param text, _orderby text, _limit int) RETURNS SETOF stuff AS $func$ BEGIN RETURN QUERY EXECUTE ' SELECT * FROM stuff WHERE col = ORDER BY ' || quote_ident(_orderby) || ' ASC LIMIT ' USING _param, _limit; END $func$ LANGUAGE plpgsql;
Diese Funktion kann wie folgt aufgerufen werden:
SELECT * FROM get_stuff('hello', 'col2', 100);
Diese Lösung vermeidet SQL-Injection-Schwachstellen, indem quote_ident() für Bezeichner und die USING-Klausel für Parameterwerte verwendet wird. Darüber hinaus gibt RETURN QUERY EXECUTE die Abfrageergebnisse effizient zurück.
Eine plpgsql-Funktion ist zwar möglicherweise ausführlicher als eine einfache SQL-Funktion, bietet jedoch eine größere Flexibilität und Leistung für komplexere Abfragen.
Das obige ist der detaillierte Inhalt vonWie kann ich parametrisierte ORDER BY- und LIMIT-Klauseln in einer PostgreSQL-Tabellenfunktion effizient implementieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!