如何解决PostgreSQL中的json-ize字符串列
我具有以下数据结构:
create table test (tags VARCHAR,tags_json VARCHAR);
insert into test (tags,tags_json)
values ('A B','["A","B"]')
我想将列tags
转换为JSON列。如果要使用tags_json
列来完成此操作非常简单:
select tags_json::JSON from test
但是当我使用tags
列运行它时,
select tags::JSON from test
我明白了
SQL Error [22P02]: ERROR: invalid input syntax for type json
如何在Postgresql中将列tags
转换为JSON列?
解决方法
您需要先将“纯文本”转换为数组,然后可以使用to_jsonb()
将其转换为正确的JSON值:
select to_jsonb(regexp_split_to_array(tags,'\s+'))
from test;
如果要永久更改列的数据类型,可以在ALTER语句中使用该表达式:
alter table test
alter tags type jsonb
using to_jsonb(regexp_split_to_array(tags,'\s+'));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。