Fra*_* M. 8 sql postgresql pgadmin
我无法找到创建(和使用)表的语法的明确解释,仅用于函数的内部计算.请问有人给我一个语法例吗?
从我发现,我已经尝试了这一点(有和没有@前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;
Run Code Online (Sandbox Code Playgroud)
我明白了:
错误:语法错误在"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;
Run Code Online (Sandbox Code Playgroud)
我得到了这个:
错误:关系"temp_table"不存在LINE 11:FROM temp_table
(显然,我知道temp_table对于我在上面的代码中所做的事情来说并不是必需的,但这不是重点:) =>我想了解使其工作的语法)
diz*_*tar 15
创建临时表的适当语法是
create temp table...
Run Code Online (Sandbox Code Playgroud)
但是你必须确保在现有函数出现之前删除临时表.另外,我建议使用这种语法:
CREATE TEMP TABLE IF NOT EXISTS temp_table AS
SELECT id, value
FROM test.another_table;
Run Code Online (Sandbox Code Playgroud)
因此你的功能将是这样的:
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;
Run Code Online (Sandbox Code Playgroud)
但如果我能这么善良,我想重写这个功能,这样更正确:
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;
Run Code Online (Sandbox Code Playgroud)
未测试; 如果失败,请告诉我.
| 归档时间: |
|
| 查看次数: |
15821 次 |
| 最近记录: |