MySQL JSON_OBJECT + CONCAT & GROUP_CONCAT 作为别名 & 截断/最大长度

标签 mysql json alias

我正在尝试通过 MySQL 将一些关系信息提取到 JSON 字符串中。但是,我使用的方法似乎截断了返回值。

MyQSL 是否对使用 CONCAT/GROUP_CONCAT/JSON_OBJECT 的查询强制执行某种最大字符串长度?我可以覆盖它吗?

(SELECT
    CONCAT(
        '[',
            GROUP_CONCAT(
                JSON_OBJECT(
                    'my_key_1', my_table.my_val_1,
                    'my_key_2', my_table.my_val_2,
                    'my_key_3', my_table.my_val_3,
                    'my_key_4', my_table.my_val_4,
                    ## [etc, etc ...]
                )
            ),
        ']' 
    )
    FROM my_table
) AS my_alias

最佳答案

使用 JSON_ARRAYAGG 而不是 GROUP_CONCAT:

SELECT
    JSON_ARRAYAGG(
        JSON_OBJECT(
            'my_key_1', my_table.my_val_1,
            'my_key_2', my_table.my_val_2,
            'my_key_3', my_table.my_val_3,
            'my_key_4', my_table.my_val_4,
            ## [etc, etc ...]
        )
    )
FROM my_table

GROUP_CONCAT 在@@group_concat_max_len 处被截断(在 MySQL 或 10.2 之前的 MariaDB 上默认为 1024,但您可以使用例如 SET @@group_concat_max_len=1000000;)进行设置;此限制不适用于 JSON_ARRAYAGG。

JSON_ARRAYAGG 需要 MySQL 5.7.22+ 或 MariaDB 10.5+

关于MySQL JSON_OBJECT + CONCAT & GROUP_CONCAT 作为别名 & 截断/最大长度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63693167/

相关文章:

Mysql - 坚持所有行的单行值?

php - Facebook 好友循环不工作

sql - mysql查询题,搞不懂

php - 选择框: how to populate days php

MySQL 存储过程说别名在 select 语句中未定义

linux - Bash:cd 到程序输出提供的目录

PHP 查询返回 null !不可能

javascript - 从 responsetext 属性中删除引号

json - 如何将 JSON 字符串作为值嵌入 Kubernetes Secret

python - ModelSerializer 是否应该按 View 编写?