首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Postgresql - JSON

Postgresql - JSON
EN

Stack Overflow用户
提问于 2016-11-12 05:29:10
回答 2查看 91关注 0票数 1

我有一个包含数据的表。我将其导出到JSON。它看起来像这样:

代码语言:javascript
运行
复制
{"@timestamp":"2015-05-18T08:57:48.646Z","ip":"0.0.0.0","extension":"php","response":"404","geo":{"coordinates":{"lat":33.48288111,"lon":-90.98561389},"src":"MD","dest":"ID","srcdest":"MD:ID"},"@tags":["success","info"]}

这样的代码行有上千行。但是,我想在JSON的每一行之前插入一个增量id,如下所示:{"index":{"_id":"1"}}。输出应如下所示:

代码语言:javascript
运行
复制
{"index":{"_id":"1"}} 
{"@timestamp":"2015-05-18T08:57:48.646Z","ip":"0.0.0.0","extension":"php","response":"404","geo":{"coordinates":{"lat":33.48288111,"lon":-90.98561389},"src":"MD","dest":"ID","srcdest":"MD:ID"},"@tags":["success","info"]}
{"index":{"_id":"2"}} 
{"@timestamp":"2015-05-18T08:57:48.646Z","ip":"0.0.0.0","extension":"php","response":"404","geo":{"coordinates":{"lat":33.48288111,"lon":-90.98561389},"src":"MD","dest":"ID","srcdest":"MD:ID"},"@tags":["success","info"]}

你知道我如何在JSON中做到这一点吗?或者我是否可以在postgres中以这种方式导出它?

EN

Stack Overflow用户

发布于 2016-11-12 15:29:16

如果没有任何额外的信息,我真的不能给你一个更好的答案,因为我知道你在一个表中对这些数据进行了标准化,所以不能在JSON|JSONB列中使用JSON

如果是这样的话,你显然知道怎么把它弄出来。您的问题似乎归结为向表中添加一列,在您的例子中名为index (尽管我建议使用另一个名称,因为index是一个保留字),也许idx是可行的。

无论如何,在不知道更多信息的情况下(例如,记录的数量,或者您必须处理的其他约束),我建议您创建一个包含序列列的新表,然后重新插入您的值,从而产生所需的结果,并在可预见的将来解决问题,例如:

代码语言:javascript
运行
复制
CREATE TABLE new_table AS SELECT * FROM old_table WITH NO DATA;
ALTER TABLE new_table ADD COLUMN idx SERIAL;
INSERT INTO new_table SELECT * FROM old_table;

这将生成一个表new_table,其中包含表old_table中的所有值和一个新列idx,其中包含您想要的ids (或者看起来像是在:之后)。

最后丢弃old_table

代码语言:javascript
运行
复制
DROP TABLE old_table;

并更新所有依赖于旧表的脚本。

希望这能让你走上正轨。

票数 0
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40556493

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档