首頁 > 資料庫 > mysql教程 > 如何使用子查詢中的值更新 PostgreSQL 行?

如何使用子查詢中的值更新 PostgreSQL 行?

DDD
發布: 2025-01-04 21:10:40
原創
227 人瀏覽過

How to Update PostgreSQL Rows with Values from a Subquery?

使用子查詢更新 PostgreSQL 表行

要使用從子查詢傳回的值來更新 PostgreSQL表中的現有行,您可以使用以下命令語法:

UPDATE table_name
SET column_name = subquery.column_name
FROM (SELECT ...) AS subquery
WHERE table_name.id = subquery.id;
登入後複製

將範例表視為虛擬表提供:

CREATE TABLE public.dummy
(
  address_id SERIAL,
  addr1 character(40),
  addr2 character(40),
  city character(25),
  state character(2),
  zip character(5),
  customer boolean,
  supplier boolean,
  partner boolean
)
WITH (
  OIDS=FALSE
);
登入後複製

要根據 select語句傳回的值更新客戶、供應商和合作夥伴列,您可以使用以下語法:

UPDATE dummy
SET customer = subquery.customer,
    supplier = subquery.supplier,
    partner = subquery.partner
FROM (SELECT address_id,
            CASE WHEN cust.addr1 IS NOT NULL THEN TRUE ELSE FALSE END AS customer,
            CASE WHEN suppl.addr1 IS NOT NULL THEN TRUE ELSE FALSE END AS supplier,
            CASE WHEN partn.addr1 IS NOT NULL THEN TRUE ELSE FALSE END AS partner
      FROM address AS pa
      LEFT OUTER JOIN cust_original AS cust
        ON (pa.addr1 = cust.addr1 AND pa.addr2 = cust.addr2 AND pa.city = cust.city
            AND pa.state = cust.state AND CAST(cust.zip AS VARCHAR(5)) = CAST(pa.zip AS VARCHAR(5)))
      LEFT OUTER JOIN supp_original AS suppl
        ON (pa.addr1 = suppl.addr1 AND pa.addr2 = suppl.addr2 AND pa.city = suppl.city
            AND pa.state = suppl.state AND CAST(pa.zip AS VARCHAR(5)) = CAST(CAST(suppl.zip AS VARCHAR(25)) AS VARCHAR(5)))
      LEFT OUTER JOIN partner_original AS partn
        ON (pa.addr1 = partn.addr1 AND pa.addr2 = partn.addr2 AND pa.city = partn.city
            AND pa.state = partn.state AND CAST(pa.zip AS VARCHAR(5)) = CAST(CAST(partn.zip AS VARCHAR(25)) AS VARCHAR(5)))) AS subquery
WHERE dummy.address_id = subquery.address_id;
登入後複製

此查詢執行以下操作:

  • 從連接虛擬表的子查詢中選擇虛擬表中每一行的客戶、供應商和合作夥伴值包含cust_original、supp_original 和Partner_original 表的虛擬表。
  • 將虛擬表中的客戶、供應商和合作夥伴欄位設定為子查詢傳回的值。
  • 僅更新子查詢中具有匹配的 address_id 的虛擬表。

以上是如何使用子查詢中的值更新 PostgreSQL 行?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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