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