服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|

服务器之家 - 数据库 - Mysql - MySQL横纵表相互转化操作实现方法

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

2021-01-21 16:29huangyuxin_ Mysql

这篇文章主要介绍了MySQL横纵表相互转化操作,结合实例形式分析了MySQL横纵表相互转化操作基本原理、实现方法与相关注意事项,需要的朋友可以参考下

本文实例讲述了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);

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

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

?
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);

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

纵表转横表

?
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;

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

纵表转横表

?
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横纵表相互转化操作实现方法

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

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

延伸 · 阅读

精彩推荐
  • MysqlMySQL 8.0.18使用clone plugin重建MGR的实现

    MySQL 8.0.18使用clone plugin重建MGR的实现

    这篇文章主要介绍了MySQL 8.0.18使用clone plugin重建MGR的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友...

    roidba3312020-12-24
  • Mysqlmysql如何在线修改主从复制选项

    mysql如何在线修改主从复制选项

    这篇文章主要介绍了mysql如何在线修改主从复制选项,帮助大家更好的理解和学习mysql,感兴趣的朋友可以了解下...

    David Beazley2922020-08-10
  • MysqlUbuntu中更改MySQL数据库文件目录的方法

    Ubuntu中更改MySQL数据库文件目录的方法

    这篇文章主要给大家介绍了关于在Ubuntu中更改MySQL数据库文件目录的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考...

    daisy5262019-06-18
  • Mysql详解MySQL集群搭建

    详解MySQL集群搭建

    本文将搭建一个最简化的MySQL Cluster系统,配置方法中的所有命令都是以root账户运行。 ...

    MYSQL教程网2212020-05-18
  • MysqlMySQL命令行导出导入数据库实例详解

    MySQL命令行导出导入数据库实例详解

    这篇文章主要介绍了MySQL命令行导出导入数据库实例详解的相关资料,需要的朋友可以参考下 ...

    MYSQL教程网5002020-06-29
  • MysqlCentOS7下MySQL5.7安装配置方法图文教程(YUM)

    CentOS7下MySQL5.7安装配置方法图文教程(YUM)

    这篇文章主要为大家详细介绍了CentOS7下MySQL5.7安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    xyang09171542020-07-12
  • MysqlMysql 建库建表技巧分享

    Mysql 建库建表技巧分享

    本文中说到的“建”,并非单纯的建一个库,或是建一张表,而是你建好的库和表在项目的运营中,是否能应付各种事件,下面我说说几个我在项目中遇到...

    MYSQL教程网5212019-11-21
  • MysqlWindows安装MySQL 5.7.18 解压版的教程

    Windows安装MySQL 5.7.18 解压版的教程

    这篇文章主要为大家详细介绍了Windows安装MySQL 5.7.18 解压版的详细教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...

    Spade-A3192020-08-04