Utilisez l'option csv pour COPY
, avec DELIMITER e'\x01' QUOTE e'\x02'
. Je ne sais pas si cela fonctionne pour tous les JSON valides possibles, mais je ne l'ai jamais vu échouer.
$ 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)