mysql select 合并列_mysql 行转列和合并列

文中所用数据库格式如下

11f55a0d1b3fd3577697d0f59bee53b4.png

查询所有学生 ORACLE开发,J2EE从入门到精通,EJB及设计模式 这三门课程的分数

SELECT

sc.grade,

tc.cname,

sc.sno

FROM

t_score sc

JOIN t_course tc ON sc.cno = tc.cno where cname='ORACLE开发' or cname='J2EE从入门到精通' or cname='EJB及设计模式’

我们查询出来的结果如下

17a2b765bc83e8cddb3a110e2e07ee8b.png

要把它从行转为列,,sql 如下

SELECT

t1.sno,

MAX( CASE t1.cname WHEN 'ORACLE开发' THEN t1.grade ELSE 0 END ) ORACLE开发,

MAX( CASE t1.cname WHEN 'J2EE从入门到精通' THEN t1.grade ELSE 0 END ) J2EE从入门到精通,

MAX( CASE t1.cname WHEN 'EJB及设计模式' THEN t1.grade ELSE 0 END ) EJB及设计模式

FROM

(

SELECT

sc.grade,

tc.cname,

sc.sno

FROM

t_score sc

JOIN t_course tc ON sc.cno = tc.cno

) t1

GROUP BY

t1.sno

结果

3b45ce816cfe9900b18ebc5b2cf25da9.png

将课程名字和成绩放在一列中,使用group_concat 函数

-- 两列合并为一列

SELECT

sno,

GROUP_CONCAT( cname, ':', grade ) AS 成绩

FROM

t_score sc

JOIN t_course co ON co.cno = sc.cno

GROUP BY

sno

得到的结果如下

7bf08d8ecb21b0f5872a866ec7e7c7a0.png

也可以使用concat(比较适用于姓和名字)

-- 两列合为一列

select concat(cno,cname) from t_course

0b5e456412e15d5b8b38dc13a174ceac.png

标签:grade,合并,t1,转列,cname,mysql,sc,cno,tc

来源: https://blog.csdn.net/Zhang_0507/article/details/106589208

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值