MySQL数据库行转换为列的2种方法

本文介绍了在MySQL中将数据库表格的行数据转换为列数据的两种方法,包括处理多表联查的复杂场景。通过示例SQL语句详细解释了转换过程,适用于需要展示类似工资条效果的查询需求。
摘要由CSDN通过智能技术生成

写在前面的话:
本博客只是为了记录我在工作中遇到的一些bug,以便日后重蹈覆辙,目前我还是一名在校大四学生,在公司实习不足半年,可能记录的问题会非常简单和出现一些错误,希望各位浏览的大神一笑而过,不吝指教,文明看帖,拒绝喷子,谢谢!
言归正传,今天在公司做个人工资结算查询的时候,需要从数据库取值(数据库为MySQL),显示为类似工资条的效果,但是数据库的表结构需要进行行转换为列,数据库表结构如下:

处理前:

这里写图片描述

处理后:

这里写图片描述
首先,贴出我要转换的表的SQL语句,这是一个多表联查,行转换为列有点复杂,后面我会写一个单表的转换语句,以便理解。

SELECT u.id,u.true_name, m.meta_name, c.amount from 
metadata m INNER JOIN charge c on c.charge_type=m.id INNER JOIN user u on c.user_id=u.id

第一种方法:

SELECT  
    a.true_name,  
    MAX(  
        CASE a.meta_name  
        
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值