Gebruik de csv-optie voor COPY
, met DELIMITER e'\x01' QUOTE e'\x02'
. Ik weet niet zeker of dit werkt voor alle mogelijke geldige JSON's, maar het is nog nooit mislukt.
$ psql -X testdb -c 'create table t(d jsonb)'
CREATE TABLE
$ cat foo.json
{"a":"Têst"}
$ cat foo.json | psql -X testdb -c "COPY t from stdin csv delimiter e'\x01' quote e'\x02'"
COPY 1
$ psql -X testdb -c 'select * from t';
d
---------------
{"a": "Têst"}
(1 row)