栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

我可以将多个MySQL行连接到一个字段中吗?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

我可以将多个MySQL行连接到一个字段中吗?

您可以使用

GROUP_CONCAT

SELECt person_id, GROUP_CONCAt(hobbies SEPARATOR ', ')FROM peoples_hobbiesGROUP BY person_id;

正如路德维希(Ludwig)在其评论中所述,您可以添加

DISTINCT
运算符以避免重复:

SELECt person_id, GROUP_CONCAt(DISTINCT hobbies SEPARATOR ', ')FROM peoples_hobbies GROUP BY person_id;

正如Jan在他们的评论中所述,您还可以在将值内插之前使用

ORDER BY
以下方法对值进行排序:

SELECt person_id, GROUP_CONCAt(hobbies ORDER BY hobbies ASC SEPARATOR ', ')FROM peoples_hobbiesGROUP BY person_id;

正如达格(Dag)在其评论中所述,结果限制为1024个字节。要解决此问题,请在查询之前运行以下查询:

SET group_concat_max_len = 2048;

当然,您可以

2048
根据需要进行更改。要计算和分配值:

SET group_concat_max_len = CAST(    (SELECt SUM(LENGTH(hobbies)) + COUNT(*) * LENGTH(', ')    FROM peoples_hobbies     GROUP BY person_id)    AS UNSIGNED);


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/367814.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号