繁体   English   中英

临时表postgresql函数

[英]Temporary table postgresql function

我无法找到创建(和使用)表的语法的明确解释,仅用于函数的内部计算。 请问有人给我一个语法例吗?

从我发现的,我尝试了这个(在temp_table之前有和没有@ ):

CREATE FUNCTION test.myfunction()
RETURNS SETOF test.out_table
AS $$

DECLARE @temp_table TABLE
( 
        id int,
        value text
 )
BEGIN
 INSERT INTO @temp_table 
        SELECT id, value
        FROM test.another_table;

 INSERT INTO test.out_table
        SELECT id, value
        FROM @temp_table;
RETURN END
$$ LANGUAGE SQL;

我明白了:

错误:语法错误在“DECLARE”第5行或附近:DECLARE @temp_table表

-

我也试过这里建议的CREATE TABLE方法,这样:

CREATE FUNCTION test.myfunction()
RETURNS SETOF test.out_table
AS $$

    CREATE TABLE temp_table AS
        SELECT id, value
        FROM test.another_table;

    INSERT INTO test.out_table
        SELECT id, value
        FROM temp_table;

$$ LANGUAGE SQL;

我得到了这个:

错误:关系“temp_table”不存在LINE 11:FROM temp_table

(显然,我知道temp_table对于我在上面的代码中所做的事情来说并不是必需的,但这不是重点:) =>我想了解使其工作的语法)

创建临时表的适当语法是

create temp table...

但是你必须确保在现有函数出现之前删除临时表。 另外,我建议使用这种语法:

CREATE TEMP TABLE IF NOT EXISTS temp_table AS
    SELECT id, value
    FROM test.another_table;

因此你的功能将是这样的:

CREATE FUNCTION test.myfunction()
RETURNS SETOF test.out_table
AS $$

    CREATE TEMP TABLE IF NOT EXISTS temp_table AS
        SELECT id, value
        FROM test.another_table;

    INSERT INTO test.out_table
        SELECT id, value
        FROM temp_table;

DROP TABLE temp_table;

$$ LANGUAGE SQL;

但如果我能这么善良,我想重写这个功能,这样更正确:

CREATE FUNCTION test.myfunction()
RETURNS TABLE (id int, value varchar) -- change your datatype as needed
AS $$
BEGIN;
CREATE TEMP TABLE IF NOT EXISTS temp_table AS
    SELECT id, value
    FROM test.another_table;

INSERT INTO test.out_table
    SELECT id, value
    FROM temp_table;

DROP TABLE temp_table;

RETURN QUERY 
SELECT id, value
from temp_table;

END;
$$ LANGUAGE plpgsql;

未测试; 如果失败,请告诉我。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM