SQLselectからJSONの配列を取得する方法

Aug 31 2020

SQLselect内にオブジェクトの配列を取得したい。

SELECT id, a.name antibodyName, c.name colorName, c.location colorLocation 
FROM Antibodies a 
JOIN AssignedColors c ON id = antiId 
WHERE colorId IS NOT NULL

そして私はこの応答を受け取ります:

[
  { id: 1, antibodyName: 'antibody 1', colorName: 'red', colorLocation: 'A5/C3' },
  { id: 2, antibodyName: 'antibody 2', colorName: 'red', colorLocation: 'C3/A1' },
  { id: 2, antibodyName: 'antibody 2', colorName: 'yellow', colorLocation: 'E4/F2' }
]

このようなものを手に入れることは可能ですか?

[
  { id: 1, antibodyName: 'antibody 1', colors: [{name: 'red, location: 'A5/C3'}] },
  { id: 2, antibodyName: 'antibody 2', colors: [{name: 'red, location: 'C3/A1'}, {name: 'yellow', location: 'E4/F2'}] },
]

回答

1 MuhammadAhmod Aug 31 2020 at 18:26

少し錆びていますが、これを試してください:

SELECT
a.id AS 'Id',
a.Name AS 'antibodyName',
c.Name AS 'name',
c.location AS 'location'
FROM Antibodies a
LEFT JOIN AssignedColors c ON c.id = a.Id
FOR JSON AUTO;

更新:上記はSQLite用ではありません。SQLiteの場合、ここでjson1拡張機能をチェックアウトする必要があります。https://www.sqlite.org/json1.html

別の更新:JSON拡張なしで実行できます...

SELECT
a.id AS 'id',
a.Name AS 'antibodyName',
(SELECT '[' || GROUP_CONCAT('{name:"' || Name || '", location:"' || location || '"}') ||']'
 FROM AssignedColors
 WHERE c.id=Id) AS colors
 FROM Antibodies a
 LEFT JOIN AssignedColors c ON c.id = a.id
 GROUP BY a.id

ここに小さな問題があります:colors列/ノードは配列ではなく文字列として扱われます... sqliteは配列型の列をサポートしていないため、これは正常です。文字列から配列に変換するには、いくつかの解析を行う必要があります。

1 sheharbano Aug 31 2020 at 18:14

json_build_objectとarray_aggを使用します。

WITH foobar AS ( 
    SELECT id, a.name antibodyName, c.name colorName, c.location colorLocation 
    FROM Antibodies a JOIN AssignedColors c
    ON id = antiId WHERE colorId IS NOT NULL
    )
SELECT 
     json_build_object('data',array_agg(json_build_object('id', id, 'antibodyName', antibodyName, 'colorName', colorName, 'colorLocation', colorLocation))
FROM 
    foobar