mysql行转列简单例子_mysql行转列、列转行示例[通俗易懂]

mysql行转列简单例子_mysql行转列、列转行示例[通俗易懂]最近在开发过程中遇到问题,需要将数据库中一张表信息进行行转列操作,再将每列(即每个字段)作为与其他表进行联表查询的字段进行显示。借此机会,在网上查阅了相关方法,现总结出一种比较简单易懂的方法备用。一、行转列:将原本同一列下多行的不同内容作为多个字段,输出对应内容。效果图:数据库表中的内容:转换后:可以看出,这里行转列是将原来的f_subject字段的多行内容选出来,作为结果集中的不同列,并根据f_…

大家好,又见面了,我是你们的朋友全栈君。

最近在开发过程中遇到问题,需要将数据库中一张表信息进行行转列操作,再将每列(即每个字段)作为与其他表进行联表查询的字段进行显示。

借此机会,在网上查阅了相关方法,现总结出一种比较简单易懂的方法备用。

一、行转列:将原本同一列下多行的不同内容作为多个字段,输出对应内容。

效果图:

数据库表中的内容:

95c2622b8c15bb3d8583c7eaeb66fda1.png

转换后:

28036e02aba4ac6ed0e534e1503eb1ef.png

可以看出,这里行转列是将原来的f_subject字段的多行内容选出来,作为结果集中的不同列,并根据f_student_id进行分组显示对应的f_score;

上SQL:

selectf_student_id,SUM(IF(f_subject=’语文’,f_score,0)) as ‘语文’,SUM(IF(f_subject=’数学’,f_score,0)) as ‘数学’,SUM(IF(f_subject=’英语’,f_score,0)) as ‘英语’

fromt_student_scoreGROUP BY f_student_id;

注意点:

1.SUM()是为了能够使用GROUP BY根据f_student_id进行分组,因为每一个student_id对应的f_subject=”语文”的记录只有一条,所以SUM()的值就等于对应那一条记录的f_score的值。

假如f_student_id =’0001′ and f_subject=’语文’ 的记录有两条,则此时SUM()的值将会是这两条记录的和,同理,使用Max()的值将会是这两条记录里面值最大的一个。但是正常情况下,一个student对应一个subject只有一个分数,因此可以使用SUM()、MAX()、MIN()、AVG()等聚合函数都可以达到行转列的效果。

2.IF(f_subject=’语文’,f_score,0)作为条件,即对所有f_subject=’语文’的记录的f_score字段进行SUM()、MAX()、MIN()、AVG()操作,如果f_score没有值则默认为0;

二、列转行:

效果图:(上面的图位置交换)

本质是将f_student_id 的每个科目分数分散成一条记录显示出来。

直接上SQL:

select f_id,f_student_id,’语文’ as f_subject,f_chinese as f_score fromt_student_subjectUNION ALL

select f_id,f_student_id,’数学’ as f_subject,f_math as f_score fromt_student_subjectUNION ALL

select f_id,f_student_id,’英语’ as f_subject,f_english as f_score from t_student_subject

这里将每个student_id对应的多个科目的成绩查出来,通过UNION ALL将结果集加起来,达到图1的效果。

附:UNION与UNION ALL的区别(摘):

1.对重复结果的处理:UNION会去掉重复记录,UNION ALL不会;

2.对排序的处理:UNION会排序,UNION ALL只是简单地将两个结果集合并;

3.效率方面的区别:因为UNION 会做去重和排序处理,因此效率比UNION ALL慢很多;

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131265.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 一眼看懂map和flatmap的区别

    一眼看懂map和flatmap的区别map的作用很容易理解就是对rdd之中的元素进行逐一进行函数操作映射为另外一个rdd。flatMap的操作是将函数应用于rdd之中的每一个元素,将返回的迭代器的所有内容构成新的rdd。通常用来切分单词。Spark中map函数会对每一条输入进行指定的操作,然后为每一条输入返回一个对象;而flatMap函数则是两个操作的集合——正是“先映射后扁平化”:操作1:同map函数一样:对每一条输入进…

    2022年5月4日
    62
  • CentOs6 Yum 源失效 404[通俗易懂]

    CentOs6 Yum 源失效 404[通俗易懂]今天下午想装点东西。。突然发现所有的6yum源都失效了YumRepoError:AllmirrorURLsarenotusingftp,http[s]orfile.Eg.Invalidrelease/repo/archcombination/removingmirrorlistwithnovalidmirrors:/var/cache/yum/x86_64/6/base/mirrorlist.txtError:Cannotfindavalid..

    2022年5月16日
    49
  • 路由器下一跳[通俗易懂]

    两台不同网段的pc通过简单配置路由器实现相互ping通1.配置两台pc的ip地址和网关2.配置R2[Huawei]intGigabitEthernet0/0/0[Huawei-GigabitEthernet0/0/0]undosh[Huawei-GigabitEthernet0/0/0]ipaddress192.168.1.25424[Huawei]intGigabitEthernet0/0/1[Huawei-GigabitEthernet0/0/1]undosh[Hu

    2022年4月10日
    540
  • golang 激活码 2021[在线序列号][通俗易懂]

    golang 激活码 2021[在线序列号],https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月18日
    82
  • HTTP 协议入门

    HTTP 协议入门

    2021年11月4日
    41
  • enumerate方法_enumerate函数的作用

    enumerate方法_enumerate函数的作用python中的获得索引、和值得方法:enumerate这种方式可以获得索引以及对应的值。但是这显得很繁琐。python其实提供了内置的enumerate函数可以同时获得索引和值,可以这样实现:forindex,keyinenumerate(sequence):process(index,key)如果你想对sequence中的元素作逆置后处理,可以:forind…

    2025年7月9日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号