在 PostgreSQL 函數中傳回結果集
在 PostgreSQL 中編寫函數時,經常需要傳回結果集。所提供的函數 wordFrequency 已使用 SETOF RECORD 傳回類型正確定義。然而,目前的實作缺乏適當的命令來傳回查詢結果。
RETURN QUERY
解決方案在於利用RETURN QUERY 指令,如下所示更正後的函數:
CREATE OR REPLACE FUNCTION word_frequency(_max_tokens int) RETURNS TABLE (txt text -- also visible as OUT param in function body , cnt bigint , ratio bigint) LANGUAGE plpgsql AS $func$ BEGIN RETURN QUERY SELECT t.txt , count(*) AS cnt -- column alias only visible in this query , (count(*) * 100) / _max_tokens -- I added parentheses FROM ( SELECT t.txt FROM token t WHERE t.chartype = 'ALPHABETIC' LIMIT _max_tokens ) t GROUP BY t.txt ORDER BY cnt DESC; -- potential ambiguity END $func$;
使用RERN TABLE
使用RETURNS TABLE 明確定義傳回類型有幾個優點:
命名註意事項
OUT 參數時要小心命名它們在整個函數體中都是可見的。為了避免衝突或混淆,請完全限定具有相同名稱的表格列,或遵循建議的命名最佳實務。
替代方案
提供的替代查詢計算相對份額每個代幣:
CREATE OR REPLACE FUNCTION word_frequency(_max_tokens int) RETURNS TABLE (txt text , abs_cnt bigint , relative_share numeric) LANGUAGE plpgsql AS $func$ BEGIN RETURN QUERY SELECT t.txt, t.cnt , round((t.cnt * 100) / (sum(t.cnt) OVER ()), 2) -- AS relative_share FROM ( SELECT t.txt, count(*) AS cnt FROM token t WHERE t.chartype = 'ALPHABETIC' GROUP BY t.txt ORDER BY cnt DESC LIMIT _max_tokens ) t ORDER BY t.cnt DESC; END $func$;
此版本採用窗口函數並確保準確的相對份額計算的數字結果。
以上是PostgreSQL函數如何有效率地傳回結果集?的詳細內容。更多資訊請關注PHP中文網其他相關文章!