dblink_build_sql_insert

dblink_build_sql_insert —使用本地 Tuples 构建 INSERT 语句,将主键字段值替换为提供的备用值

Synopsis

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

Description

dblink_build_sql_insert在将本地表选择性复制到远程数据库中很有用。它基于主键从本地表中选择一行,然后构建一个 SQL INSERT命令,该命令将复制该行,但主键值将替换为最后一个参数中的值。 (要精确复制该行,只需为最后两个参数指定相同的值.)

Arguments

  • relname

    • 本地关系的名称,例如foomyschema.mytab。如果名称是大小写混合的或包含特殊字符,例如"FooBar",则用双引号引起来。不带引号的字符串将被折叠为小写。
  • primary_key_attnums

    • 主键字段的属性编号(从 1 开始),例如1 2
  • num_primary_key_atts

    • 主键字段的数量。
  • src_pk_att_vals_array

    • 用于查找本地 Tuples 的主键字段的值。每个字段均以文本形式表示。如果没有具有这些主键值的本地行,则会引发错误。
  • tgt_pk_att_vals_array

    • 要放置在结果INSERT命令中的主键字段的值。每个字段均以文本形式表示。

Return Value

以文本形式返回请求的 SQL 语句。

Notes

从 PostgreSQL 9.0 开始,* primary_key_attnums *中的属性编号被解释为逻辑列编号,对应于SELECT * FROM relname中列的位置。以前的版本将数字解释为物理列位置。如果在表的生命周期内删除了指定列左侧的任何列,则存在差异。

Examples

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)