postgresql – Postgres – 复制(剥离双引号)

postgresql – Postgres – 复制(剥离双引号),第1张

概述我使用Postgres 8.4.4 copy, http://www.postgresql.org/docs/8.4/static/sql-copy.html,将CSV数据导入我的数据库.我的源数据中的一些值包含双引号,这些双引号在插入时被剥离,而当我通过psql执行INSERT或UPDATE语句以测试双引号时会保留.也许给出一个关于发生了什么的线索,一些值也包含逗号,这些逗号根据需要保留. 我试 我使用Postgres 8.4.4 copy,http://www.postgresql.org/docs/8.4/static/sql-copy.html,将CSV数据导入我的数据库.我的源数据中的一些值包含双引号,这些双引号在插入时被剥离,而当我通过psql执行INSERT或UPDATE语句以测试双引号时会保留.也许给出一个关于发生了什么的线索,一些值也包含逗号,这些逗号根据需要保留.

我试图在http://www.postgresql.org/docs/8.3/interactive/sql-syntax-lexical.html解决问题的基础,但没有成功.

我正在使用的复制命令是:

copy my_table (fIEld_1,fIEld_2,fIEld_3 ...) from '/tmp/source.csv' with csv

源数据使用逗号分隔符双引号.如有必要,可以更改…

“价值”,“另一个价值”,“这是”另一个“价值”,“不再,谢谢”

解决方法 您必须引用嵌入式引号.
默认值是它们的两倍,因此您的数据应为:

"value","another value","this is ""another"" value","no more,thanks"

另一种方法是不加引号(但你必须引用逗号,如果有的话),就像

value,another value,this is "another" value,no more,thanks

更新:这是有效的,但你必须确保引用嵌入的”(在这种情况下通过添加反斜杠)

DROP table tmp.my_table CASCADE;CREATE table tmp.my_table        ( fIEld_1 varchar,fIEld_2 varchar,fIEld_3 varchar,fIEld_4 varchar        );copY tmp.my_table (fIEld_1,fIEld_3,fIEld_4)FROM STDINWITH CSV DEliMITER ',' QUOTE '"' ESCAPE '\'        ;"value","this is \"another\" value",thanks"\.        ;SELECT * FROM tmp.my_table;
总结

以上是内存溢出为你收集整理的postgresql – Postgres – 复制(剥离双引号)全部内容,希望文章能够帮你解决postgresql – Postgres – 复制(剥离双引号)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1161379.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存