首頁 >資料庫 >mysql教程 >我應該將公共子查詢儲存為 PostgreSQL 中的表格列嗎?

我應該將公共子查詢儲存為 PostgreSQL 中的表格列嗎?

Patricia Arquette
Patricia Arquette原創
2025-01-11 18:46:42632瀏覽

Should I Store Common Subqueries as Table Columns in PostgreSQL?

將常用查詢儲存為表格列?

查詢:

考慮以下 PostgreSQL 查詢:

<code class="language-sql">SELECT <col>, <col>
     , (SELECT sum(<colx>)
        FROM   <othertable> 
        WHERE  <otherforeignkeycol> = <thiskeycol>) AS <col>
FROM   <tbl>;</code>

此子查詢在多個查詢中保持不變。是否可以將此子查詢儲存為表的偽列,以便輕鬆選擇表示基於記錄關係的表 B 中列的總和的表 A 中的列?

答案:

1. 視圖

建立視圖是一種有效的解決方案,可讓您定義一個虛擬表,其中所需子查詢作為其列之一。

2. 計算欄位(儲存產生的欄位)

PostgreSQL 11 中引入的儲存所產生的資料列符合您的要求。這些允許您定義一個根據其他列的值(包括子查詢)動態計算的列。

使用計算欄位的實作:

考慮以下表格:

<code class="language-sql">CREATE TABLE tbl_a (a_id int, col1 int, col2 int);
CREATE TABLE tbl_b (b_id int, a_id int, colx int);</code>

使用函數建立計算欄位:

<code class="language-sql">CREATE FUNCTION col3(a_id INT)
  RETURNS int8
  LANGUAGE sql STABLE AS
$func$
SELECT sum(colx)
FROM   tbl_b b
WHERE  b.a_id = 
$func$;</code>

現在,您可以查詢:

<code class="language-sql">SELECT a_id, col1, col2, col3(a_id)
FROM   tbl_a;</code>

說明:

計算欄位透過根據表中目前行提供指定列的值來模擬子查詢。使用屬性表示法存取計算欄位(例如,col3(a_id))。此技術允許動態檢索計算值並保持與 SELECT * 查詢的兼容性。 注意,這裡修改了函數定義,直接使用a_id作為參數,避免了使用記錄的寫法,簡化了查詢。

以上是我應該將公共子查詢儲存為 PostgreSQL 中的表格列嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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