將常用查詢儲存為表格列?
查詢:
考慮以下 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中文網其他相關文章!