首頁 > 資料庫 > mysql教程 > 如何在 PostgreSQL 中使用陣列參數有效率地多次呼叫傳回集合的函數?

如何在 PostgreSQL 中使用陣列參數有效率地多次呼叫傳回集合的函數?

Mary-Kate Olsen
發布: 2024-12-30 07:35:18
原創
494 人瀏覽過

How Can I Efficiently Call a Set-Returning Function Multiple Times with Array Arguments in PostgreSQL?

多次呼叫帶有陣列參數的集合回傳函數

在PostgreSQL 中,您可能會遇到需要多次呼叫集合回傳函數的情況,每次提供一個數組作為參數。然而,當使用傳統的將單一數組傳遞給函數的方法時,函數可能會被多次調用,導致處理效率低下。

為了解決這個問題,PostgreSQL 9.3 及更高版本提供了 LEFT JOIN LATERAL 。 ..ON 正確的語法。此方法透過執行以下步驟來最佳化執行:

  1. LEFT JOIN LATERAL 語句將子查詢中的資料與呼叫設定傳回函數 foo(sub.arr) 的結果連接起來。
  2. ON true 子句確保子查詢中的所有行都包含在結果中,無論函數是否回傳任何rows.

為了說明這種方法,請考慮以下範例:

SELECT sub.dataid, f.*
FROM  (
   SELECT dataid, array_agg(data) AS arr
   FROM   dataset
   WHERE  dataid = something
   GROUP  BY 1
   ) sub
LEFT   JOIN LATERAL foo(sub.arr) f ON true;
登入後複製

在此範例中,子查詢會聚合每個dataid 的資料列,建立一個陣列。然後,該數組作為參數傳遞給 foo() 函數,該函數會傳回一組增強的資料行。

或者,如果 foo() 函數可能不傳回任何行,而您希望保留所有行在連接的左側,您可以使用 CROSS JOIN LATERAL 或簡寫語法。

利用此方法,您可以有效地多次呼叫集合返回函數數組參數,避免不必要的函數呼叫。

以上是如何在 PostgreSQL 中使用陣列參數有效率地多次呼叫傳回集合的函數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板