[英]Import CSV file via PSQL With Array Values
我有一个非常简单的表,我想将 CSV 中的数据插入其中。
create table products(
id integer primary key,
images text[]
);
这是我目前正在尝试使用 csv 的内容:
1,"['hello.jpg', 'world.jpg']"
2,"['hola.jpg', 'mundo.jpg']"
当我执行以下操作时,我从 psql 收到语法错误,没有其他信息可能出了什么问题。
\copy products 'C:\Users\z\Downloads\MOCK_DATA.csv' WITH DELIMITER ',';
有谁知道如何正确格式化我的数组值?
如果您从csv
文件中删除方括号,那么我将拥有这样的表格( images
作为text
而不是text[]
):
create table products_raw
(
id integer primary key,
images text
);
加上这个观点
create view products as
select id, ('{'||images||'}')::text[] as images
from products_raw;
并在以后使用该视图。 无论如何,我宁愿拥有这样的 CSV 文件,没有格式化,只有数据:
1,"hello.jpg,world.jpg"
2,"hola.jpg,mundo.jpg"
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.