首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么JSON_ARRAYAGG函数的LIMIT子句失败?

为什么JSON_ARRAYAGG函数的LIMIT子句失败?
EN

Stack Overflow用户
提问于 2019-11-13 02:04:19
回答 1查看 225关注 0票数 2

使用JSON_ARRAYAGG函数时,limit子句似乎不起作用。

有没有更好的方法来实现这个功能?

代码语言:javascript
复制
SELECT * FROM USER_TABLE ORDER BY RAND() LIMIT 2;
--> Gives me 2 random employee details - which is perfect.

SELECT JSON_ARRAYAGG(JSON_OBJECT('userId', user_id)) FROM USER_TABLE ORDER BY RAND() LIMIT 2;
--> Gives me ALL the employee details. - which is INCORRECT.
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-11-13 02:27:06

如果使用不带GROUP BY子句的JSON_ARRAYAGG(),您将只得到一行。只有到那时,LIMIT 2才会被应用,并且(当然)对这一行没有任何影响。您可能需要在FROM子句中使用LIMIT 2子查询:

代码语言:javascript
复制
SELECT JSON_ARRAYAGG(json_obj)
FROM (
    SELECT JSON_OBJECT('userId', user_id) as json_obj
    FROM USER_TABLE
    ORDER BY RAND()
    LIMIT 2
) x

代码语言:javascript
复制
SELECT JSON_ARRAYAGG(JSON_OBJECT('userId', user_id))
FROM (
    SELECT user_id
    FROM USER_TABLE
    ORDER BY RAND()
    LIMIT 2
) x
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58824292

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档