mysql groupby 字段合并问题(group_concat)

mysql groupby 字段合并问题(group_concat) 在我们的日常mysql查询中,我们可能会遇到这样的情况: 对表中的所有记录进行分类,并且我需要得到每个分类中某个字段的全部成员。 上面的话,大家看起来可能不太好懂,下面举一个例子来给大家说明…

	mysql groupby 字段合并问题(group_concat)[数据库教程]

   在我们的日常mysql查询中,我们可能会遇到这样的情况:

    对表中的所有记录进行分类,并且我需要得到每个分类中某个字段的全部成员。

  上面的话,大家看起来可能不太好懂,下面举一个例子来给大家说明。

  现在我们有一张表,结构如下:

  技术图片

 

   现在我们向这张表中插入一些数据。  

    insert into test_group_concat  values(default,1,‘ppaa‘,1594802453,0),(default,1,‘llcc‘,1594802453,0),(default,2,‘uupp‘,1594802453,0),(default,2,‘ttww‘,1594802453,0)

  现在我们可以看到,数据表的情况如下:

  技术图片

 

   我的需要是这样的:我需要对type_id进行分组,而且每个分组下的所有name我都要得到,这个是后应该怎么办呢?

  这样写:select type_id,name from test_group_concat GROUP BY type_id

  我们得到的结果是这样的:

  技术图片

 

   上面每个type_id对应只有一个name,这显然不符合我们的需求,我们的需求是需要找出type_id = 1 这个分类下所有的name,和type_id = 2的所有的name。

  怎么办呢?

  有朋友会想到,“用concat就可以解决问题了嘛!”,好的,我们现在试一下。

  select type_id,concat(name) as names from test_group_concat GROUP BY type_id

  结果如下:

  技术图片

 

   很显然,没有达到我们的预期,怎么办!!!

  mysql中给我们提供了一个函数:group_concat,利用这个函数,我们就能够很好的解决上述问题。我们试一下。

  select type_id,group_concat(name) as names from test_group_concat GROUP BY type_id

  结果如下:

  技术图片

 

  上述结果,很好的满足了我们的需求。

  那有朋友就会问了,如果我不仅想知道分类某个字段的全部信息,我还想要某两个字段连接在一起的所有信息,我们可以这么去写。

  select type_id,group_concat(id,‘,‘,name) as names from test_group_concat GROUP BY type_id

  技术图片

 

mysql groupby 字段合并问题(group_concat)

原文地址:https://www.cnblogs.com/573734817pc/p/13306625.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/7351.html

(0)
上一篇 2023-03-21
下一篇 2023-03-21

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注