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)
如果您在文档中看到任何不正确的内容,与您对特定功能的体验不符或需要进一步说明,请使用 此表格 报告文档问题。