Postgresql 将动态参数数传递给函数
我需要将动态数量的参数及其数据类型传递给函数,然后返回一个以这些参数为字段的表。 在研究生中有可能做到这一点吗?Postgresql 将动态参数数传递给函数,postgresql,Postgresql,我需要将动态数量的参数及其数据类型传递给函数,然后返回一个以这些参数为字段的表。 在研究生中有可能做到这一点吗? 任何想法或例子都值得赞赏这里有一个可能改进的例子 小心SQL注入 CREATE OR REPLACE FUNCTION create_table( tabname text, VARIADIC coldef text[] ) RETURNS void LANGUAGE plpgsql STRICT AS $$DECLARE l integer; i in
任何想法或例子都值得赞赏这里有一个可能改进的例子 小心SQL注入
CREATE OR REPLACE FUNCTION create_table(
tabname text,
VARIADIC coldef text[]
) RETURNS void
LANGUAGE plpgsql STRICT AS
$$DECLARE
l integer;
i integer;
sql text;
sep text := '';
BEGIN
l := array_upper(coldef, 1);
IF l % 2 <> 0 THEN
RAISE EXCEPTION 'Number of arguments must be odd';
END IF;
sql := 'CREATE TABLE ' || quote_ident(tabname) || '(';
FOR i IN 1 .. l/2 LOOP
sql := sql || sep || quote_ident(coldef[2*i-1]) || ' ' || quote_ident(coldef[2*i]);
sep := ', ';
END LOOP;
sql := sql || ')';
EXECUTE sql;
END;$$;
谢谢你的回复
test=> SELECT create_table('tabname', 'col1', 'int4', 'col2', 'text');
test=> \d tabname
Table "laurenz.tabname"
┌────────┬─────────┬───────────┐
│ Column │ Type │ Modifiers │
├────────┼─────────┼───────────┤
│ col1 │ integer │ │
│ col2 │ text │ │
└────────┴─────────┴───────────┘