我知道您可以从文件中运行这样的复制命令:
"COPY zip_codes FROM '/path/to/csv/ZIP_CODES.txt' DELIMITER ',' CSV;"
我想从 ruby 变量中复制 csv 数据,这样我就可以这样做
"COPY zip_codes FROM '#{csv_data}' DELIMITER ',' CSV;"
我知道您可以从文件中运行这样的复制命令:
"COPY zip_codes FROM '/path/to/csv/ZIP_CODES.txt' DELIMITER ',' CSV;"
我想从 ruby 变量中复制 csv 数据,这样我就可以这样做
"COPY zip_codes FROM '#{csv_data}' DELIMITER ',' CSV;"
COPY
SQL命令无法做到这一点。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 或更高版本。