MySql中GROUP_CONCAT的使用
程序员文章站
2024-03-20 08:32:28
...
在我们使用数据库时,会碰到这样一种情况:同一个Name的人有两条数据,但是他们的其他数据并不相同,而我们所需要的是同一个Name的人的Score1集合,即需要获得Name为A的所有的Score1并且希望将其拼接为一个字段,这里我们就需要用到GROUP_CONCAT。
函数语法如下:group_concat( 要连接的字段 ) [Order BY 排序字段 ASC/DESC] [Separator '分隔符']
select Name,GROUP_CONCAT(Score1 Separator '-') FROM MyTable GROUP BY Name;
其中GROUP BY 后面的字段是Name,所有同一排序字段的数据会被拼接后存入同一字段中,并以相应的分隔符分分隔。
如上的sql语句,返回值为:
因为上面的数据中只有Name为A和D的两项数据有重复,所有他们的Score1是拼接出来的。
值得注意的是GROUP_CONCAT是有长度限制的,MySQL对其的默认长度限制为1024,可以使用如下语句来进行修改长度:
SHOW VARIABLES LIKE "%group_concat_max_len%"//查看长度
SET SESSION group_concat_max_len = 102400; //修改长度
推荐阅读
-
mysql中GROUP_CONCAT()函数的含义及用法
-
MySql中GROUP_CONCAT的使用
-
使用dom4j中的XPath查询 博客分类: dom4j dom4jxpath
-
使用dom4j中的XPath查询 博客分类: dom4j dom4jxpath
-
eclipse RCP 开发中的程序参数使用 博客分类: eclipse
-
Echarts中dataZoom的使用
-
Yii 中 session 与 cookie 的使用
-
python中的bisect模块的使用
-
mybatis中的 mybatis-generator:generate 代码生成器的使用
-
Mysql中的递归层次查询(父子查询,无限极查询)