在PostgreSQL中,你可以使用PL/pgSQL函数或者SQL语句来生成INSERT语句。以下是一个使用PL/pgSQL函数的例子,该函数会遍历表中的所有行,为每一行生成一个INSERT语句:
CREATE OR REPLACE FUNCTION generate_insert_statements(tablename TEXT) RETURNS SETOF TEXT AS $$
DECLARE
row_values TEXT;
column_list RECORD;
first_column BOOLEAN = TRUE;
BEGIN
FOR column_list IN
SELECT column_name
FROM information_schema.columns
WHERE table_schema = 'public' AND table_name = tablename
LOOP
IF first_column THEN
first_column := FALSE;
row_values := '(';
ELSE
row_values := row_values || ', ';
END IF;
row_values := row_values || quote_ident(column_list.column_name);
END LOOP;
row_values := row_values || ') VALUES (';
FOR column_list IN
SELECT column_name
FROM information_schema.columns
WHERE table_schema = 'public' AND table_name = tablename
LOOP
IF first_column THEN
first_column := FALSE;
ELSE
row_values := row_values || ', ';
END IF;
row_values := row_values || 'EXCLUDED.' || quote_ident(column_list.column_name);
END LOOP;
row_values := row_values || ')';
RETURN QUERY EXECUTE format(
'INSERT INTO %I %s',
tablename,
row_values
);
END;
$$ LANGUAGE plpgsql;
使用该函数时,你需要指定表名作为参数。函数会返回一个包含生成的INSERT语句的集合。
请注意,这个函数生成的INSERT语句使用了“EXCLUDED”关键字来引用新插入行的值。这是在使用ON CONFLICT
子句时的一个特殊用法,它在冲突发生时插入新行。如果你不需要这种特性,你可能需要修改函数来适应你的需求。