dblink_build_sql_delete — 使用提供的字段值构建一个 DELETE 语句
dblink_build_sql_delete(text relname, int2vector primary_key_attnums, integer num_primary_key_atts, text[] tgt_pk_att_vals_array) returns text
dblink_build_sql_delete
可用于将本地表有选择地复制到远程数据库中。它会构建一个 SQL DELETE
命令,此命令将根据给定的主键值删除该行。
relname
本地关系的名称,例如 foo
或 myschema.mytab
。如果名称是混合大小写或包含特殊字符,请包含双引号,例如 "FooBar"
;如果不加引号,则会将字符串折叠为小写。
primary_key_attnums
主键字段的属性编号(以 1 为基数),例如 1 2
。
num_primary_key_atts
主键字段的数量。
tgt_pk_att_vals_array
将在结果 DELETE
命令中使用的主键字段的值。每个字段都以文本形式表示。
以文本形式返回请求的 SQL 语句。
从 PostgreSQL 9.0 开始,primary_key_attnums
中的属性编号被解释为逻辑列编号,对应于 SELECT * FROM relname
中列的位置。以前版本将数字解释为物理列位置。如果在表的生命周期中删除了指示列左侧的任何列,则存在差异。
SELECT dblink_build_sql_delete('"MyFoo"', '1 2', 2, '{"1", "b"}'); dblink_build_sql_delete --------------------------------------------- DELETE FROM "MyFoo" WHERE f1='1' AND f2='b' (1 row)