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    │           │
└────────┴─────────┴───────────┘