MySQL列转行(group_concat函数)
在MySQL中,如何将列转成一行?比如一个一个商品会属于多个分类(如华为手机可以是手机分类,也可以是数码分类),如何将此商品在一条数据中展现所有分类。思路很简单,通过MySQL函数group_concat即可解决。创建测试表:create table test.test_mysql_liezhuanhang (idbigint auto_increment comment '主键',namevar
·
在MySQL中,如何将列转成一行?比如一个一个商品会属于多个分类(如华为手机可以是手机分类,也可以是数码分类),如何将此商品在一条数据中展现所有分类。
思路很简单,通过MySQL函数group_concat即可解决。
创建测试表:
create table test.test_mysql_liezhuanhang (
id bigint auto_increment comment '主键',
name varchar(100),
age int(5),
primary key (id)
)engine=innodb default charset=utf8mb4 comment='测试表'
导入测试数据:
insert into test.test_mysql_liezhuanhang (name, age) values ('李威', 18), ('李威', 19), ('李威', 18), ('李白', 20), ('李白', 20), ('李白', 19);
展现所有名字,以分号分割,默认以,
分割
select group_concat(name separator ';') concat
from test.test_mysql_liezhuanhang
;
展现所有名字,并将相同名字去重
select group_concat(distinct name) concat
from test.test_mysql_liezhuanhang
;
展现所有年龄,去重并以年龄升序排序
select group_concat(distinct age order by age) concat
from test.test_mysql_liezhuanhang
;
更多推荐
已为社区贡献3条内容
所有评论(0)