关于 Group 的另一个函数
总第155篇/张俊红
今天给大家分享一下关于 Group 的另一个函数 Group_Concat。
先给大家科普两个概念,宽表和窄表。
宽表是将多个维度的信息放在一个表中,组成一个很宽很宽的表。比如订单明细表里面存放了用户相关信息、产品相关信息、渠道相关信息,总共好几百列数据。这种表就是宽表。
窄表是将不同维度的表放在不同表,最后根据公共列进行链接。比如订单表只放了订单相关信息、用户表放了用户相关信息、渠道表放了渠道相关信息,当你需要获取订单的整体情况的时候,就需要把用到的这几个窄表先拼接起来,再调取你需要的字段。
了解完了宽表与窄表的概念以后,我们来看一个需求。
现在有一张表 u:
userid | first_name | last_name | city |
---|---|---|---|
001 | 张 | 飞 | 北京 |
002 | 李 | 蛋 | 上海 |
003 | 王 | 明 | 北京 |
004 | 杨 | 一 | 北京 |
我们想要获取每个用户的姓名,但是数据库中存储的姓和名是分开的,一列是存储的姓、一列存储的名,所以我们需要把这两列给拼接起来。拼接字段我们可以用 concat。具体代码如下:
select userid,concat(first_name,last_name) as name from u
最后结果如下:
userid | name |
---|---|
001 | 张飞 |
002 | 李蛋 |
003 | 王明 |
004 | 杨一 |
现在又有另外一张表 r,这张表存储了每个用户的每个角色,一个用户是可以有多个角色,且每个角色存储一行,比如用户 1 有1、2两个角色,所以存储了两行。
userid | roleid |
---|---|
1 | 1 |
1 | 2 |
2 | 1 |
2 | 2 |
2 | 3 |
3 | 1 |
3 | 2 |
3 | 3 |
3 | 4 |
现在我们有这么一个需求,需要把每个用户的角色放在一起,也就是一行,并用逗号分隔开。这个时候我们就可以使用 Group_Concat 了。
具体代码如下:
select userid,group_concat(roleid) as roleid from r group by userid
Group_Concat 一般都需要与 Group by 结合使用,先对表中的 userid 进行分组,然后再对分组后的 roleid 进行 concat。最后得到结果如下:
userid | roleid |
---|---|
1 | 1,2 |
2 | 1,2,3 |
3 | 1,2,3,4 |
这样每个用户的所有角色id就拼接在了一起。
你还可以看:
Sql 的执行顺序是怎样的?
Sql 实现数据透视表功能
讲讲你不知道的窗口函数
讲讲 group by 的plus版
介绍一下 information_schema 库
关于 Group 的另一个函数相关推荐
- einsum,一个函数走天下
作者 | 永远在你身后 转载自知乎 [导读]einsum 全称 Einstein summation convention(爱因斯坦求和约定),又称为爱因斯坦标记法,是爱因斯坦 1916 年提出的一种 ...
- 一个函数打天下,einsum
作者丨永远在你身后@知乎 来源丨https://zhuanlan.zhihu.com/p/71639781 编辑丨极市平台 einsum全称Einstein summation convention( ...
- ACMNO.24 C语言-转置矩阵 写一个函数,使给定的一个二维数组(3×3)转置,即行列互换。 输入 一个3x3的矩阵 输出 转置后的矩阵 样例
题目描述 写一个函数,使给定的一个二维数组(3×3)转置,即行列互换. 输入 一个3x3的矩阵 输出 转置后的矩阵 样例输入 1 2 3 4 5 6 7 8 9 样例输出 1 4 7 2 5 8 3 ...
- C语言---写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串
题目: 写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串. #include <string.h> #include <stdio.h> void left_re ...
- 进入编译器后,一个函数经历了什么?
我是一个函数 我是一个函数,名叫str_upper,我可以把输入的字符串从小写变成大写.不信你看,我长这样: char* str_upper(char* str, int len) {char upp ...
- c语言fac函数求n的阶乘,急求C语言编辑题:Cnm=n!/m!(n-m)!其中n,m 由键盘输入。要求设计一个函数fac(n)求某个正整数n 的阶乘。...
急求C语言编辑题:Cnm=n!/m!(n-m)!其中n,m 由键盘输入.要求设计一个函数fac(n)求某个正整数n 的阶乘. 來源:互聯網 2010-05-29 01:44:10 評論 分類: 電 ...
- R语言按组聚合求和实战(sum a variable by group):使用aggregate函数按组聚合求和、使用tapply函数按组聚合求和、按组聚合求和(使用dplyr包)
R语言按组聚合求和实战(sum a variable by group):使用aggregate函数按组聚合求和.使用tapply函数按组聚合求和.按组聚合求和(使用dplyr包) 目录
- 写一个函数,2 个参数,1 个字符串,1 个字节数,返回截取的字符串,要求字符串中的中文不能出现乱码
题目要求: 写一个函数,2 个参数,1 个字符串,1 个字节数,返回截取的字符串,要求字符串中的中文不能出现乱码. 如("我ABC",4)应该截为"我AB", ...
- 编写一个函数进行左移或右移的位运算
<程序设计基础-c语言>杨莉 刘鸿翔 ISBN-978-7-03-032903-5 p166 习题6 8.编写一个函数int move(int value,char direction,i ...
最新文章
- 如何成为一名Android架构师,乃至高级架构师,文末有路线图
- JS获取并操作iframe中元素的方法
- CString::Format
- MYSQL [ERROR] InnoDB: Unable to lock ./ibdata1 error: 11
- 本人开源项目 Lu-Rpc
- 提取javadoc_使用JavaParser从源文件中提取JavaDoc文档
- mysql concat 引号_在MySQL concat里面使用多个单引号,三引号的问题
- 一步一步写算法(之 可变参数)
- mongodb空间查询java,java查看mongodb集合表空间大小
- 千古奇闻!明朝就已成功试爆两万吨原子弹?
- visual studio 中将选中代码相同的代码的颜色设置,修改高亮颜色
- 琴岛学院计算机工程系怎么样,青岛理工大学琴岛学院计算机工程系学子荣获全国网络技术挑战赛二等奖...
- js ajax 同步 执行完js之后才执行插入html
- phpstudy安装及简单使用教程
- 厉害了,大米云Linux搭建Wordpress环境
- 优化 | 线性化:0-1变量乘以连续变量的线性化
- edge浏览器使用IE模式进行调试
- 2.zookeeper
- 最全C++知识点--重载运算与类型转换
- python爬虫相关坑坑洼洼