0

我的问题:我需要动态定义外部表并每次设置不同的 where 条件。我在函数中执行此操作,但在创建外部表(通过 oracle_fdw)期间遇到对我没有意义的错误。

创建有效的外部表:

CREATE FOREIGN TABLE MYFOREIGNTABLE 
(
column1 int,
column2 text
)
SERVER fwdb
OPTIONS (table $$(
  select
    column1,
    column2
  from
    table1
  where 
   column3 = 5
   and column4 = 'a'
)$$);

现在,如果我尝试拆分字符串以将我的变量放在那里(而不是我留下的变量编号以便任何人都可以尝试),它会停止工作并且我收到错误

[代码:0,SQL 状态:42601] 错误:“||”处或附近的语法错误

CREATE FOREIGN TABLE MYFOREIGNTABLE 
(
column1 int,
column2 text
)
SERVER fwdb
OPTIONS (table $$(
  select
    column1,
    column2
  from
    table1
  where 
   column3 = $$ || 5 || $$
   and column4 = 'a'
)$$);

只是为了确定我在选择中尝试了我的字符串以确保我没有犯任何语法错误并且它没有问题

select $$(
  select
    column1,
    column2
  from
    table1
  where 
   column3 = $$ || 5 || $$
   and column4 = 'a'
)$$

我尝试了其他一些方法,例如使用 concat() 或将整个字符串放入变量OPTIONS (table myvariable);中,但都没有奏效。这里的正确语法是什么?

x86_64-pc-linux-gnu 上的 PostgreSQL 11.10,由 gcc (GCC) 4.8.5 20150623 (Red Hat 4.8.5-39) 编译,64 位

4

1 回答 1

2

您必须使用字符串文字作为 FDW 选项的值,不允许您尝试使用的字符串连接等表达式。

例如,您必须使用动态 SQL 构建完整的语句

DO
$$DECLARE
   var integer := 5;
BEGIN
   EXECUTE
      format(
         E'CREATE FOREIGN TABLE MYFOREIGNTABLE (\n'
         '   column1 int,\n'
         '   column2 text\n'
         ') SERVER fwdb OPTIONS (\n'
         '   table ''(SELECT column1,\n'
         '                   column2\n'
         '            FROM table1\n'
         '            WHERE column3 = %s\n'
         '              AND column4 = ''''a'''')'')',
         var
      );
END;$$;

对于字符串变量,您必须使用quote_literal(quote_literal(var)).

于 2020-12-02T09:23:35.707 回答