PostgreSQL
 sql >> Base de données >  >> RDS >> PostgreSQL

problème d'encodage lors de l'importation de json dans Postgres

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)