MySql怎么操作列转行函数,要注意什么
导读:在实际案例的操作过程中,我们可能会遇到“MySql怎么操作列转行函数,要注意什么”这样的问题,那么我们该如何处理和解决这样的情况呢?这篇小编就给大家总结了一些方法,具有一定的借鉴价值,希望对大家有所帮助,接下来就让小编带领大家一起了解看看吧...
在实际案例的操作过程中,我们可能会遇到“MySql怎么操作列转行函数,要注意什么”这样的问题,那么我们该如何处理和解决这样的情况呢?这篇小编就给大家总结了一些方法,具有一定的借鉴价值,希望对大家有所帮助,接下来就让小编带领大家一起了解看看吧。在mysql中,列转行函数是“group_concat()”函数;该函数用于将非空列值按照分组条件进行合并并最终返回,如果其中有空值则返回的结果是空,语法为“select group_concat(name separator '; ')列名 from 表名; ”。
本教程操作环境:windows10系统、mysql8.0.22版本、Dell G3电脑。
mysql列转行函数是什么
GROUP_CONCAT(expr)该函数将非空列值按照分组条件进行合并并最终返回。如果有空值,则返回为空
在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
;
登录后复制
感谢各位的阅读,以上就是“MySql怎么操作列转行函数,要注意什么”的内容了,通过以上内容的阐述,相信大家对MySql怎么操作列转行函数,要注意什么已经有了进一步的了解,如果想要了解更多相关的内容,欢迎关注网络,网络将为大家推送更多相关知识点的文章。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: MySql怎么操作列转行函数,要注意什么
本文地址: https://pptw.com/jishu/649744.html