首頁 >資料庫 >mysql教程 >PostgreSQL函數如何有效率地傳回結果集?

PostgreSQL函數如何有效率地傳回結果集?

Mary-Kate Olsen
Mary-Kate Olsen原創
2025-01-17 10:26:14194瀏覽

How to Efficiently Return Result Sets in PostgreSQL Functions?

在 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 參數的資料類型以符合查詢的回傳

命名註意事項

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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn