如何将 jsonb 数组分解为 postgresql 查询的行

How to break out jsonb array into rows for a postgresql query

我有 objective 将 table 上的查询结果分解为包含数组的 json 列。但是我不确定编写此查询的语法。我正在使用这个:

对于以下查询

SELECT
       jobs.id,
       templates.Id,
       templates.Version,
       templates.StepGroupId,
       templates.PublicVersion,
       templates.PlannedDataSheetIds,
       templates.SnapshottedDataSheetValues
FROM jobs,
     jsonb_to_recordset(jobs.source_templates) AS templates(Id, Version, StepGroupId, PublicVersion,
                                                            PlannedDataSheetIds, SnapshottedDataSheetValues)

关于以下table:

create table jobs
(
    id uuid default uuid_generate_v4() not null
        constraint jobs_pkey
            primary key,
    source_templates jsonb,
);

jsonb 列包含以下格式的数据:

[  
   {  
      "Id":"94729e08-7d5c-459d-9244-f66e17059fc4",
      "Version":1,
      "StepGroupId":"0274590b-c08d-4963-b37e-8fc8f25151d2",
      "PublicVersion":1,
      "PlannedDataSheetIds":null,
      "SnapshottedDataSheetValues":null
   },
   {  
      "Id":"66791bfd-8cdb-43f7-92e6-bfb45b0f780f",
      "Version":4,
      "StepGroupId":"126404c5-ed1e-4796-80b1-ca68ad486682",
      "PublicVersion":1,
      "PlannedDataSheetIds":null,
      "SnapshottedDataSheetValues":null
   },
   {  
      "Id":"e3b31b98-8052-40dd-9405-c316b9c62942",
      "Version":4,
      "StepGroupId":"bc6a9dd3-d527-449e-bb36-39f03eaf87b9",
      "PublicVersion":1,
      "PlannedDataSheetIds":null,
      "SnapshottedDataSheetValues":null
   }
]

我收到一个错误:

[42601] ERROR: a column definition list is required for functions returning "record"

在不产生错误的情况下执行此操作的正确方法是什么?

您需要定义数据类型:

SELECT
       jobs.id,
       templates.Id,
       templates.Version,
       templates.StepGroupId,
       templates.PublicVersion,
       templates.PlannedDataSheetIds,
       templates.SnapshottedDataSheetValues
FROM jobs,
     jsonb_to_recordset(jobs.source_templates) 
         AS templates(Id UUID, Version INT, StepGroupId UUID, PublicVersion INT,
                      PlannedDataSheetIds INT, SnapshottedDataSheetValues INT)