关于 Group 的另一个函数

总第155篇/张俊红

今天给大家分享一下关于 Group 的另一个函数 Group_Concat。

先给大家科普两个概念,宽表和窄表。

宽表是将多个维度的信息放在一个表中,组成一个很宽很宽的表。比如订单明细表里面存放了用户相关信息、产品相关信息、渠道相关信息,总共好几百列数据。这种表就是宽表。

窄表是将不同维度的表放在不同表,最后根据公共列进行链接。比如订单表只放了订单相关信息、用户表放了用户相关信息、渠道表放了渠道相关信息,当你需要获取订单的整体情况的时候,就需要把用到的这几个窄表先拼接起来,再调取你需要的字段。

了解完了宽表与窄表的概念以后,我们来看一个需求。

现在有一张表 u:

useridfirst_namelast_namecity
001北京
002上海
003北京
004北京

我们想要获取每个用户的姓名,但是数据库中存储的姓和名是分开的,一列是存储的姓、一列存储的名,所以我们需要把这两列给拼接起来。拼接字段我们可以用 concat。具体代码如下:

select userid,concat(first_name,last_name) as name from u

最后结果如下:

useridname
001张飞
002李蛋
003王明
004杨一

现在又有另外一张表 r,这张表存储了每个用户的每个角色,一个用户是可以有多个角色,且每个角色存储一行,比如用户 1 有1、2两个角色,所以存储了两行。

useridroleid
11
12
21
22
23
31
32
33
34

现在我们有这么一个需求,需要把每个用户的角色放在一起,也就是一行,并用逗号分隔开。这个时候我们就可以使用 Group_Concat 了。

具体代码如下:

select userid,group_concat(roleid) as roleid from r group by userid

Group_Concat 一般都需要与 Group by 结合使用,先对表中的 userid 进行分组,然后再对分组后的 roleid 进行 concat。最后得到结果如下:

useridroleid
11,2
21,2,3
31,2,3,4

这样每个用户的所有角色id就拼接在了一起。

你还可以看:

Sql 的执行顺序是怎样的?

Sql 实现数据透视表功能

讲讲你不知道的窗口函数

讲讲 group by 的plus版

介绍一下 information_schema 库

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

俊红的数据分析之路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值