Postgres Copy from Variable with CSV data

后端 未结 1 911
野趣味
野趣味 2020-12-21 14:37

I know you can run a copy command like this from a file:

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

I\'d l

相关标签:
1条回答
  • 2020-12-21 14:59

    That's not possible with the SQL COPY command. COPY only copies from a file or STDIN.

    You can either write the content of the variable to a file or pipe it via STDIN. Only makes sense for more than a couple of rows.


    I think I misunderstood your question before the update, you probably don't need this:

    The file path can not be exchanged like other data items, and you can't use a prepared statement for that. Build the whole statement before executing or resort to dynamic SQL with a server-side function like:

    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;
    

    Call:

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

    format() requires Postgres 9.1 or later.

    0 讨论(0)
提交回复
热议问题