group by JSON包含数组的列

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

我有下表:

Table

包含这些数据:

Data

如何按我的JSON列中的数组项进行分组?得到这个结果:

Expected Result

sql sql-server group-by sql-server-2016
2个回答
1
投票

您可以尝试使用OPENJSONCROSS APPLY来制作它。

SELECT
    col1,
     UserID
FROM T t1
CROSS APPLY
    OPENJSON(t1.Roles)
    WITH
        (
            col1 varchar(50) N'$'
        ) AS a

sqlfiddle


1
投票

如果你不能使用OPENJSON,这里有一个替代方案

Select
    aRole, COUNT(*) as cnt
From (

    Select
        a.ID
        ,b.Items as aRole
    From 
        (Select *
            ,replace(replace(replace(Roles,'[',''),']',''),'"','') as Rolesx
         From JSONgroup) a
    Cross Apply dbo.Split(a.Rolesx, ',') b
) c
 group by aRole
© www.soinside.com 2019 - 2024. All rights reserved.