Mysql之使用自连接的方法实现行转列

在Mysql中如何将图一转变成图二,让我们慢慢来实现

图一在这里插入图片描述图二在这里插入图片描述

1、首先我们得准备两张

one_usertable
在这里插入图片描述
killtable
在这里插入图片描述
2、执行下面的sql语句,进行对每一个人的数量进行汇总

SELECT one_usertable.username, SUM(killtable.kills_number) as "数量" 
from one_usertable JOIN killtable on 
one_usertable.id =killtable.user_id GROUP BY one_usertable.username

得出如下的结果,那么现在是行的形式了,接下来,我们进行转列的形式
在这里插入图片描述
3、执行下面的sql语句

SELECT * FROM (
SELECT  SUM(killtable.kills_number) as "陈小燕" 
 from one_usertable JOIN killtable on 
one_usertable.id =killtable.user_id  and one_usertable.username="陈小燕"
) a CROSS JOIN(
SELECT  SUM(killtable.kills_number) as "陈小蝶" 
 from one_usertable JOIN killtable on 
one_usertable.id =killtable.user_id  and one_usertable.username="陈小蝶"
) b CROSS JOIN(
SELECT SUM(killtable.kills_number) as "陈小水" 
 from one_usertable JOIN killtable on 
one_usertable.id =killtable.user_id  and one_usertable.username="陈小水") c

那么我们要显示的行转列就会实现出来了
在这里插入图片描述

还有第二种实现方法,我们接下来实现CASE方法来实现

SELECT sum(case WHEN username="陈小燕" then kills_number end) as '陈小燕',
       sum(case WHEN username="陈小蝶" then kills_number end) as '陈小蝶',
       sum(case WHEN username="陈小水" then kills_number end) as '陈小水'
FROM one_usertable JOIN killtable on one_usertable.id=killtable.user_id

得出来的结果仍然是
在这里插入图片描述
但是我们用这两种行转列是存在一个缺点的,比如说,我们连接join次数会随着用户的次数增加而增加,影响效率不高,而且还会带来给我们写sql的复杂性,虽然在开发中我们用这种的技巧并不是很多,但是我们每天学多一点就是进步一点。

优秀的程序员一定是在不停的进步的,我们一起加油

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值