MySQL横纵表相互转化操作实现方法

吾爱主题 阅读:193 2024-04-05 16:21:45 评论:0

本文实例讲述了mysql横纵表相互转化操作实现方法。分享给大家供大家参考,具体如下:

先创建一个成绩表(纵表)

?
1 2 3 4 5 6 7 8 9 10 11 create table user_score (    name varchar (20),    subjects varchar (20),    score int ); insert into user_score( name ,subjects,score) values ( '张三' , '语文' ,60); insert into user_score( name ,subjects,score) values ( '张三' , '数学' ,70); insert into user_score( name ,subjects,score) values ( '张三' , '英语' ,80); insert into user_score( name ,subjects,score) values ( '李四' , '语文' ,90); insert into user_score( name ,subjects,score) values ( '李四' , '数学' ,100);

再创建一个成绩表(横表)

?
1 2 3 4 5 6 7 8 9 create table user_score2 (    name varchar (20),    yuwen int ,    shuxue int ,    yingyu int ); insert into user_score2( name ,yuwen,shuxue,yingyu) values ( '张三' ,60,70,80); insert into user_score2( name ,yuwen,shuxue,yingyu) values ( '李四' ,90,100,0);

纵表转横表

?
1 2 3 4 select name , sum ( case subjects when '语文' then score else 0 end ) as '语文' , sum ( case subjects when '数学' then score else 0 end ) as '数学' , sum ( case subjects when '英语' then score else 0 end ) as '英语' from user_score group by name ;

纵表转横表

?
1 2 3 4 select  name , 'yuwen'  as   subjects,yuwen  as  score  from  user_score2  union  all select  name , 'shuxue'  as   subjects,shuxue  as  score  from  user_score2 union  all select  name , 'yingyu'  as   subjects,yingyu  as  score  from  user_score2 order by name ,subjects desc ;

希望本文所述对大家MySQL数据库计有所帮助。

原文链接:https://blog.csdn.net/huangyuxin_/article/details/79678719

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容