如何在JSON列Postgres中附加到嵌套数组

发布于 2025-02-04 21:29:16 字数 337 浏览 3 评论 0原文

我的列具有下一个结构:

 {
  "_id": "57101c4efbea42d219e068b3",
  "name": "System admin group",
  "is_service": 0,
  "security_lists": {
    "actions": [
      "ota upload",
      "widgets manage",
      "scheduled jobs manage all",
      "users view"
    ]
  }
}

如何将值附加到操作数组中? 我想可以使用JSONB_SET()完成它,但是我不知道该怎么做(

I have column with the next structure:

 {
  "_id": "57101c4efbea42d219e068b3",
  "name": "System admin group",
  "is_service": 0,
  "security_lists": {
    "actions": [
      "ota upload",
      "widgets manage",
      "scheduled jobs manage all",
      "users view"
    ]
  }
}

How can I append value to actions array?
I suppose that it's can be done using jsonb_set() but I can't figure out how to do it(

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

踏雪无痕 2025-02-11 21:29:16
    UPDATE 
        group_permissions 
    SET 
        "document"=jsonb_set("document"::jsonb, 
        '{security_lists, actions}', 
        ("document" ->'security_lists'->'actions')::jsonb || 
        '["newString"]'::jsonb) 
    WHERE 
        "document"::json->>'name'='System admin group';
    UPDATE 
        group_permissions 
    SET 
        "document"=jsonb_set("document"::jsonb, 
        '{security_lists, actions}', 
        ("document" ->'security_lists'->'actions')::jsonb || 
        '["newString"]'::jsonb) 
    WHERE 
        "document"::json->>'name'='System admin group';
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文