临时表postgresql函数
发布时间:2020-12-13 16:30:54 所属栏目:百科 来源:网络整理
导读:我无法找到创建(和使用)表的语法的明确解释,仅用于函数的内部计算.请问有人给我一个语法例吗? 从我发现的,我尝试了这个(在temp_table之前有和没有@): CREATE FUNCTION test.myfunction()RETURNS SETOF test.out_tableAS $$DECLARE @temp_table TABLE( id i
我无法找到创建(和使用)表的语法的明确解释,仅用于函数的内部计算.请问有人给我一个语法例吗?
从我发现的,我尝试了这个(在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; 我明白了:
– 我也试过建议here的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对于我在上面的代码中所做的事情不是必需的,但那不是重点:) =>我想了解让它工作的语法)
创建临时表的适当语法是
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 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; 未测试;如果失败,请告诉我. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |