dblink_build_sql_insert — 使用本地元组构建一个 INSERT 语句,用提供的备选值替换主键字段值
dblink_build_sql_insert(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_insert
可用于对本地表执行有选择的复制,以实现远程数据库。它根据主键从本地表中选择一行,然后构建一个 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
要放入结果 INSERT
命令的主键字段的值。每个字段以文本形式表示。
将请求的 SQL 语句作为文本返回。
自 PostgreSQL 9.0 起,primary_key_attnums
中的属性编号按逻辑列号来解释,它对应于 SELECT * FROM relname
中的列位置。之前的版本将这些数字解释为物理列位置。如果表生命周期期间已删除指向指示列左侧的任何列,则存在差异。
SELECT dblink_build_sql_insert('foo', '1 2', 2, '{"1", "a"}', '{"1", "b''a"}'); dblink_build_sql_insert -------------------------------------------------- INSERT INTO foo(f1,f2,f3) VALUES('1','b''a','1') (1 row)