我想对 json_arrayagg() 返回的数组进行排序。 我的查询与此类似:-
select A, json_arrayagg(json_obj('X',value1, 'Y',value2)) AS RESULT
FROM (derived table)
GROUP BY A.
我想要的是我希望返回的数组按 value2 排序。 我尝试在末尾添加 order by 子句(例如,按 value2 排序:它不起作用)
已尝试在 json_arrayagg() 内部添加顺序..(例如:json_arrayagg(json_obj() order by value2) 它不起作用。
已尝试使用 group_concat ,但它不可靠并且不知道为什么它没有返回正确的数据。已检查限制。
请建议我如何解决这个问题? 谢谢
最佳答案
显然,有一个 hack 可能会起作用:
SELECT A, json_arrayagg(json_obj('X',value1, 'Y',value2)) AS RESULT
FROM (SELECT . . .,
ROW_NUMBER() OVER (ORDER BY value2) as seqnum
FROM . . .
. . .
) x
GROUP BY A;
ROW_NUMBER()
——显然——设法对结果集进行排序,即使 ORDER BY
不起作用。
关于mysql - 如何在 Mysql 中对 json_arrayagg() 返回的数组进行排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63252941/