gpt4 book ai didi

mysql - 如何在 Mysql 中对 json_arrayagg() 返回的数组进行排序?

转载 作者:行者123 更新时间:2023-12-05 03:50:55 25 4
gpt4 key购买 nike

我想对 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com