繁体   English   中英

GROUP_CONCAT()mysql返回有限字符

[英]GROUP_CONCAT() mysql returns limited characters

我要两张桌子

tblColorLibrary

id   name
1     test color

tblColors

id  libraryId  colorCode  name
1     1           #fff     Prime Color
2     1           #ddd     Secondry Color
3     1           #E2CFC7  Favorite Color

以下是我的查询:

$stmt ="SELECT a.id, a.isActive as isActive, a.name as title, GROUP_CONCAT(b.colorCode ) as colors, GROUP_CONCAT(b.name) as name FROM ".$this->tblLibrary." as a JOIN tblcolors as b ON a.id = b.libraryId GROUP BY a.id ORDER BY b.id ASC";

该查询将返回这样的结果

Array
(
    [0] => Array
        (
            [id] => 1
            [isActive] => Y
            [title] => test
            [colors] => #fff,#ddd,#E2CFC7
            [name] => Prime Color, Secondry Color, Favorite Color
        )

)

一切顺利,直到我的唱片有限。 当我在tblColors中有150条以上的记录时,名称键仅提供有限数量的字符。 没有完整的记录。

我想小组比赛中会有局限性。

在mysql数据库中增加group_concat_max_len。 默认情况下,它设置为1024。您可以使用查询进行更新

SET GLOBAL group_concat_max_len=100000

SET SESSION group_concat_max_len = 1000000;

检查group_concat_max_len的值,并根据需要增加它的值。

show variables like 'group_concat_max_len';

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM