dblink_build_sql_update — 使用本地元組構建 UPDATE 語句,將主鍵欄位值替換為提供的備用值
dblink_build_sql_update(text relname, int2vector primary_key_attnums, integer num_primary_key_atts, text[] src_pk_att_vals_array, text[] tgt_pk_att_vals_array) returns text
dblink_build_sql_update
在將本地表選擇性複製到遠端資料庫時非常有用。它根據主鍵從本地表中選擇一行,然後構建一個 SQL UPDATE
命令來複制該行,但將主鍵值替換為最後一個引數中的值。(要製作行的精確副本,只需為最後兩個引數指定相同的值。) UPDATE
命令始終分配行的所有欄位 — 與 dblink_build_sql_insert
的主要區別在於,它假定目標行已存在於遠端表中。
relname
本地關係(表)的名稱,例如 foo
或 myschema.mytab
。如果名稱是大小寫混合的或包含特殊字元,請包含雙引號,例如 "FooBar"
;不帶引號,字串將摺疊為小寫。
primary_key_attnums
主鍵欄位的屬性號(從 1 開始),例如 1 2
。
num_primary_key_atts
主鍵欄位的數量。
src_pk_att_vals_array
用於查詢本地元組的主鍵欄位值。每個欄位都以文字形式表示。如果不存在具有這些主鍵值 的本地行,則會丟擲錯誤。
tgt_pk_att_vals_array
將放入生成的 UPDATE
命令中的主鍵欄位值。每個欄位都以文字形式表示。
返回請求的 SQL 語句(作為文字)。
自 PostgreSQL 9.0 起,primary_key_attnums
中的屬性號被解釋為邏輯列號,對應於 SELECT * FROM relname
中列的位置。之前的版本將這些數字解釋為物理列位置。如果指定的列左側的任何列在表生命週期內已被刪除,則存在差異。
SELECT dblink_build_sql_update('foo', '1 2', 2, '{"1", "a"}', '{"1", "b"}'); dblink_build_sql_update ------------------------------------------------------------- UPDATE foo SET f1='1',f2='b',f3='1' WHERE f1='1' AND f2='b' (1 row)
如果您在文件中發現任何不正確、與您對特定功能的體驗不符或需要進一步澄清的內容,請使用 此表單 報告文件問題。