一尘不染

使用CSV数据从Postgres复制

sql

我知道您可以从文件运行这样的复制命令:

"COPY zip_codes FROM '/path/to/csv/ZIP_CODES.txt' DELIMITER ',' CSV;"

我想从ruby变量中复制csv数据,所以我可以这样做

"COPY zip_codes FROM '#{csv_data}' DELIMITER ',' CSV;"

阅读 163

收藏
2021-03-17

共1个答案

一尘不染

使用SQLCOPY命令是不可能的。COPY仅从 文件STDIN 复制。

您可以将变量的内容写入文件,也可以通过STDIN将其传递。仅适用于多于几行。


我想我在更新之前误解了您的问题,您可能不需要这个:

文件路径不能像其他数据项一样交换,因此您不能使用准备好的语句。在执行或诉诸动态SQL之前,先通过服务器端函数构建 整个 语句,例如:

CREATE OR REPLACE FUNCTION f_cp(_file text)
  RETURNS void AS
$BODY$
BEGIN
EXECUTE format($$COPY zip_codes FROM %L DELIMITER ',' CSV$$, $1);
END
$BODY$
  LANGUAGE plpgsql;

称呼:

SELECT f_cp('/var/lib/postgres/sync/myfile.csv')

format() 需要Postgres 9.1或更高版本。

2021-03-17