从 CSV 文件(逗号分隔)创建 postgres 外部表,该文件有一个电子邮件列,其中多个电子邮件地址用逗号分隔
Posted
技术标签:
【中文标题】从 CSV 文件(逗号分隔)创建 postgres 外部表,该文件有一个电子邮件列,其中多个电子邮件地址用逗号分隔【英文标题】:Creating a postgres External table from a CSV file (comma separated) which has an email column with multiple email addressed separated by comma 【发布时间】:2014-03-20 15:35:37 【问题描述】:我正在尝试从 CSV 文件创建一个 postgres 外部表,该文件的一列作为电子邮件地址,并且该列有多个电子邮件地址,以逗号分隔。由于文件的分隔符是逗号,因此在创建外部表时,无法区分列内的“,”和列之间的“,”。电子邮件列中的电子邮件列表也用双引号括起来。 有没有办法在不改变整个文件的分隔符的情况下加载它?
【问题讨论】:
到目前为止你尝试了什么?你运行的是哪个版本的 PostgreSQL? ..您使用哪种编程语言,或者您想使用哪种编程语言来创建 SQL 插入命令? 【参考方案1】:CSV 的标准做法是用双引号将字段括起来。COPY... CSV
将直接导入。
例子:
CREATE TABLE email(id int, emails text);
COPY email FROM STDIN CSV;
输入要复制的数据,后跟换行符。
以反斜杠和单独一行的句点结束。
>> 1,"abc@example.com,def@example.com"
>> \。
结果:
从电子邮件中选择 * ; 编号 |电子邮件 --+------------------------------------ 1 | abc@example.com,def@example.com (1 行)【讨论】:
以上是关于从 CSV 文件(逗号分隔)创建 postgres 外部表,该文件有一个电子邮件列,其中多个电子邮件地址用逗号分隔的主要内容,如果未能解决你的问题,请参考以下文章