PostgreSQL,试图将日期列从 csv 文件复制到表的列

Posted

技术标签:

【中文标题】PostgreSQL,试图将日期列从 csv 文件复制到表的列【英文标题】:PostgreSQL, trying to copy column of dates from csv file to table's column 【发布时间】:2020-07-05 00:51:36 【问题描述】:

我有一个 PostgreSQL 表,其中包含一个“日期”类型的空列

我正在尝试从 CSV 文件中复制日期值。

但它提出了这一点:

COPY books (publication_date) FROM 'path/to/file/pub.csv' CSV;
ERROR:  date/time field value out of range: "11/31/2000"

此值位于 CSV 的索引 8178 处,因此不是整个文件有问题。

我不明白为什么,因为日期似乎很好。

那么,我该如何解决这个问题或让 Postgres 忽略错误的日期?

【问题讨论】:

【参考方案1】:
ERROR:  date/time field value out of range: "11/31/2000"

我不明白为什么,因为日期似乎很好。

嗯,11月只有30天,所以日期确实无效。

【讨论】:

没错,写了一个函数来改变这些错误的行并且它起作用了。【参考方案2】:

您需要将日期样式设置为所需的格式。 https://www.postgresql.org/docs/7.2/sql-set.html https://www.postgresql.org/docs/9.1/runtime-config-client.html#GUC-DATESTYLE

SET datestyle = DMY;

【讨论】:

以上是关于PostgreSQL,试图将日期列从 csv 文件复制到表的列的主要内容,如果未能解决你的问题,请参考以下文章

使用 PowerShell 将列从一个 csv 文件复制到另一个

如何将列从一个 CSV 文件复制到另一个 CSV 文件?

如何使用 re.split 在 python 中拆分两列从 CSV 中查找字符串值

错误:Postgresql 中的日期/时间字段值超出范围

如何在python flask app中将数据从postgresql渲染到csv?

将重复的列从 CSV 转换为嵌套的 BigQuery 表?