将数据从Postgres DB提取到JSON多级层次结构

问题描述 投票:0回答:1

我试图从postgres数据库中提取数据到JSON文件。这里的问题是,我需要将多个hirarchy中的数据加载到JSON文件中。

任何在postgres SQL查询或python中实现这一点的解决方案都将非常感激。

我尝试在一个级别上执行它并通过postgres上的json_agg()查询成功,但不知道如何执行超过2级别的操作。

这是我的postgres代码:

select
    json_build_object('column1',json_agg(
    json_build_object('name',column1,'column2',column2)))
     table1
from table;

which gives me :
[columns1:
{column2:value},
{column2:value2}
]

But what i need is:
eg: column1 column2 column3
    4       1       4
    4       4       5
    4       1       9
    2       3       7
    3       1       8
    1       1       1
    3       1       6

    output:
    [
    column1:4[{
      column2:1[{
        column3:4,
        colun3:9}]
    },
    { column2:4
      [{
        column3:5
      }]
    }]]
python sql json postgresql hierarchy
1个回答
0
投票

以下是两种不同的变体,因为您的输出不是有效的JSON,因此有点难以猜测您想要的格式:

下面的两个变体都具有相同的查询结构,并且在创建JSON对象的方式上有所不同。

对于更多级别的层次结构,您需要更多CTE,如agg_c3,或者您重写查询以使用嵌套的子选择(如果您愿意)(但是比CTE更难读取)。

包裹的键值

WITH
    my_table (col1, col2, col3) AS (
        VALUES (4,1,4), (4,4,5), (4,1,9), (2,3,7), (3,1,8), (1,1,1), (3,1,6)
    ),
    agg_c3 AS (
        SELECT col1, col2, jsonb_build_object('column3', jsonb_agg(jsonb_build_object('value', col3))) AS col3
        FROM my_table
        GROUP BY 1, 2
    ),
    agg_c2 AS (
        SELECT col1, jsonb_build_object('column2', jsonb_agg(jsonb_build_object('value', col2) || col3)) AS col2
        FROM agg_c3
        GROUP BY 1
    )
SELECT jsonb_build_object('column1', jsonb_agg(jsonb_build_object('value', col1) || col2)) AS json_object
FROM agg_c2
;

...的回报:

{
  "column1": [
    {
      "value": 1,
      "column2": [
        {
          "value": 1,
          "column3": [
            {
              "value": 1
            }
          ]
        }
      ]
    },
    {
      "value": 3,
      "column2": [
        {
          "value": 1,
          "column3": [
            {
              "value": 8
            },
            {
              "value": 6
            }
          ]
        }
      ]
    },
    {
      "value": 2,
      "column2": [
        {
          "value": 3,
          "column3": [
            {
              "value": 7
            }
          ]
        }
      ]
    },
    {
      "value": 4,
      "column2": [
        {
          "value": 1,
          "column3": [
            {
              "value": 4
            },
            {
              "value": 9
            }
          ]
        },
        {
          "value": 4,
          "column3": [
            {
              "value": 5
            }
          ]
        }
      ]
    }
  ]
}

值,只

WITH
    my_table (col1, col2, col3) AS (
        VALUES (4,1,4), (4,4,5), (4,1,9), (2,3,7), (3,1,8), (1,1,1), (3,1,6)
    ),
    agg_c3 AS (
        SELECT col1, col2, jsonb_agg(col3) AS col3
        FROM my_table
        GROUP BY 1, 2
    ),
    agg_c2 AS (
        SELECT col1, jsonb_agg(jsonb_build_object(col2::text, col3)) AS col2
        FROM agg_c3
        GROUP BY 1
    )
SELECT jsonb_agg(jsonb_build_object(col1::text, col2)) AS json_object
FROM agg_c2
;

...的回报:

[
  {
    "1": [
      {
        "1": [
          1
        ]
      }
    ]
  },
  {
    "3": [
      {
        "1": [
          8,
          6
        ]
      }
    ]
  },
  {
    "2": [
      {
        "3": [
          7
        ]
      }
    ]
  },
  {
    "4": [
      {
        "1": [
          4,
          9
        ]
      },
      {
        "4": [
          5
        ]
      }
    ]
  }
]
© www.soinside.com 2019 - 2024. All rights reserved.