dblink_build_sql_delete
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) 返回 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)
文章转载自PostgreSQL全球开发组,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。