【转】Mysql行转换为列
From : http://www.cnblogs.com/lhj588/archive/2012/06/15/2550392.html#
今晚需要统计数据生成简易报表,由原表格数据是单行的形式,最好转换为列表格式,由网上介绍方法实现如下:
希望获得的最终效果见下:
+-------+------+-------+-------+--------+--------+--------+---------------------+---------+
| 房间 | 房租 | 水费 | 电费 | 卫生费 | 电视费 | 网络费 | 记录时间 | total |
+-------+------+-------+-------+--------+--------+--------+---------------------+---------+
| 0201 | 400 | 0 | 0 | 10 | 0 | 0 | 2011-02-08 11:01:21 | 410 |
| 0204 | 150 | 0 | 0 | 10 | 0 | 0 | 2011-02-08 11:00:21 | 160 |
| 0206 | 150 | 0 | 0 | 10 | 0 | 0 | 2011-01-16 18:02:50 | 160 |
| 0302 | 350 | 40.92 | 18.91 | 20 | 50 | 50 | 2011-01-18 01:45:23 | 529.83 |
| 0306 | 150 | 0 | 0 | 10 | 0 | 0 | 2011-02-08 11:23:15 | 160 |
| 0308 | 200 | 0 | 0 | 10 | 0 | 0 | 2011-03-28 22:26:41 | 210 |
| total | 1400 | 40.92 | 18.91 | 70 | 50 | 50 | 2011-03-28 22:26:41 | 1629.83 |
+-------+------+-------+-------+--------+--------+--------+---------------------+---------+
实现的SQL语句见下:
mysql> SELECT
-> IFNULL(RoomNo,'total') AS 房间,
-> SUM(IF(FeeName='房租',FeeMoney,0)) AS 房租,
-> SUM(IF(FeeName='水费',FeeMoney,0)) AS 水费,
-> SUM(IF(FeeName='电费',FeeMoney,0)) AS 电费,
-> SUM(IF(FeeName='卫生费',FeeMoney,0)) AS 卫生费,
-> SUM(IF(FeeName='电视费',FeeMoney,0)) AS 电视费,
-> SUM(IF(FeeName='网络费',FeeMoney,0)) AS 网络费,
-> IFNULL(CDate, CDate) AS 记录时间,
-> SUM(IF(FeeName='total',FeeMoney,0)) AS total
-> FROM (
-> select no.RoomNo as RoomNo, IFNULL(f.FeeName, 'total') as FeeName, SUM(f.FeeMoney) as FeeMoney, f.CreateDate as CDate
-> from roomnoinfo no, Fee f
-> where no.bid=1 and no.beempty='full' and no.RoomNo=f.RoomNo and
-> f.CreateDate < '2011-03-31' and f.CreateDate >'2011-01-01'
-> GROUP BY RoomNO, FeeName
-> WITH ROLLUP
-> HAVING RoomNO IS NOT NULL
-> ) AS A
-> GROUP BY RoomNo
-> WITH ROLLUP;
源数据的表格式如下:
mysql> select RoomNo, CreateDate, FeeName, FeeMoney from Fee where bid=1;
+--------+---------------------+---------+----------+
| RoomNo | CreateDate | FeeName | FeeMoney |
+--------+---------------------+---------+----------+
| 0101 | 2011-01-15 22:41:24 | 房租 | 200 |
| 0101 | 2011-01-15 22:41:24 | 水费 | 13.2 |
| 0101 | 2011-01-15 22:41:24 | 电费 | 6.1 |
| 0102 | 2011-01-16 17:01:52 | 房租 | 150 |
| 0102 | 2011-01-16 17:01:52 | 水费 | 145.2 |
| 0102 | 2011-01-16 17:01:52 | 电费 | 67.1 |
| 0102 | 2011-01-16 17:01:52 | 卫生费 | 10 |
| 0204 | 2011-02-08 11:00:21 | 房租 | 150 |
| 0204 | 2011-02-08 11:00:21 | 水费 | NULL |
| 0204 | 2011-02-08 11:00:21 | 电费 | NULL |
| 0204 | 2011-02-08 11:00:21 | 卫生费 | 10 |
| 0206 | 2011-01-16 18:02:50 | 房租 | 150 |
| 0206 | 2011-01-16 18:02:50 | 水费 | NULL |
| 0206 | 2011-01-16 18:02:50 | 电费 | NULL |
| 0206 | 2011-01-16 18:02:50 | 卫生费 | 10 |
| 0302 | 2011-01-18 01:42:35 | 房租 | 150 |
| 0302 | 2011-01-18 01:42:35 | 水费 | 40.92 |
| 0302 | 2011-01-18 01:42:35 | 电费 | 18.91 |
| 0302 | 2011-01-18 01:42:35 | 卫生费 | 10 |
| 0302 | 2011-01-18 01:45:23 | 卫生费 | 10 |
| 0302 | 2011-01-18 01:45:23 | 房租 | 200 |
| 0302 | 2011-01-18 01:45:23 | 网络费 | 50 |
| 0302 | 2011-01-18 01:45:23 | 电视费 | 50 |
| 0306 | 2011-02-08 11:23:15 | 房租 | 150 |
| 0306 | 2011-02-08 11:23:15 | 水费 | NULL |
| 0306 | 2011-02-08 11:23:15 | 电费 | NULL |
| 0306 | 2011-02-08 11:23:15 | 卫生费 | 10 |
| 0308 | 2011-03-28 22:26:41 | 房租 | 200 |
| 0308 | 2011-03-28 22:26:41 | 水费 | NULL |
| 0308 | 2011-03-28 22:26:41 | 电费 | NULL |
| 0308 | 2011-03-28 22:26:41 | 卫生费 | 10 |
+--------+---------------------+---------+----------+
31 rows in set (0.02 sec)
原文介绍地址 http://blogold.chinaunix.net/u3/90603/showart_2017912.html
|
【转】Mysql行转换为列的更多相关文章
- MYSQL 行转列 以及基本的聚合函数count,与group by 以及distinct组合使用
在统计查询中,经常会用到count函数,这里是基础的 MYSQL 行转列 以及基本的聚合函数count,与group by 以及distinct组合使用 -- 创建表 CREATE TABLE `tb ...
- excel中怎么将行转换为列及列转换成行
操作方法 01 选中要把行转换为列的数据.然后点击键盘上的ctrl+c. 02 在需要放置的单元格上,右键点击,然后点击菜单上的‘选择性粘贴’. 03 在弹出的窗口上,点击勾选上‘转置’.点击确定按钮 ...
- MySQL 行转列 -》动态行转列 -》动态行转列带计算
Pivot Table Using MySQL - A Complete Guide | WebDevZoomhttp://webdevzoom.com/pivot-table-using-mysql ...
- MySql 行转列 存储过程实现
同学们在使用mysql的过程中,会遇到一个行转列的问题,就是把多条数据转化成一条数据 用多列显示. 方法1. 实现方式用下面的存储过程,表名对应的修改就行. BEGIN declare current ...
- mysql行转列,函数GROUP_CONCAT(expr)
demo: 语句: SELECT '行' id, '' product_nameUNIONSELECT id, product_name FROM `product` WHERE id < 5 ...
- mysql行转列 问题 SUM(IF(条件,列值,0))
sum(if(条件,列值,0))语法用例: select name,sum(if(subject="语文",score,0)) as "语文" from gra ...
- mysql行转列、列转行示例
最近在开发过程中遇到问题,需要将数据库中一张表信息进行行转列操作,再将每列(即每个字段)作为与其他表进行联表查询的字段进行显示. 借此机会,在网上查阅了相关方法,现总结出一种比较简单易懂的方法备用. ...
- MySQL行转列、列转行
一.行转列 有如图所示的表,现在希望查询的结果将行转成列 建表语句如下: CREATE TABLE `TEST_TB_GRADE` ( `ID` int(10) NOT NULL AUTO_INCRE ...
- mysql 行转列 列转行
一.行转列 即将原本同一列下多行的不同内容作为多个字段,输出对应内容. 建表语句 DROP TABLE IF EXISTS tb_score; CREATE TABLE tb_score( id ) ...
随机推荐
- hive1.2.1安装步骤(在hadoop2.6.4集群上)
hive1.2.1在hadoop2.6.4集群上的安装 hive只需在一个节点上安装即可,这里再hadoop1上安装 1.上传hive安装包到/usr/local/目录下 2.解压 tar -zxvf ...
- 【IObit】五大软件激活码( Advanced Systemcare....)
IObit Malware Fighter 6Pro 破解: 打开软件安装位置,下载替换dll文件 链接: https://pan.baidu.com/s/1Euz87MCANuCnRqZsMQ_w4 ...
- ubuntu18.04 安装mysql不出现设置 root 帐户的密码问题(装)
ubuntu18.04 安装mysql不出现设置 root 帐户的密码问题 https://blog.csdn.net/NeptuneClouds/article/details/80995 ...
- DFT,DTFT,DFS,FFT区别
学习了数字信号处理之后,被里面的几个名词搞的晕头转向,比如DFT,DTFT,DFS,FFT,FT,FS等,FT和FS属于信号与系统课程的内容,是对连续时间信号的处理,这里就不过多讨论,只解释一 ...
- css3中的伪类选择器
一.动态伪类 动态伪类,因为这些伪类并不存在于HTML中,而只有当用户和网站交互的时候才能体现出来,动态伪类包含两种,第一种是我们在链接中常看到的锚点伪类,如":link",&qu ...
- Eth-Trunk链路聚合配置
Eth-Trunk概述 Eth-Trunk接口能够实现负载分担.增加带宽和提高可靠性 Eth-Trunk接口把多个物理接口捆绑成一个逻辑接口 Eth-Trunk接口的链路聚合模式 链路聚合模式 应用场 ...
- Mac 下的 .app文件如何生成.dmg ?
安装 Node.js最新版. 安装方法不赘述. 安装 create-dmg: sudo npm install --global create-dmg 注意这里 sudo不能少. 终端切换到 .app ...
- 循序渐进学.Net Core Web Api开发系列【11】:依赖注入
系列目录 循序渐进学.Net Core Web Api开发系列目录 本系列涉及到的源码下载地址:https://github.com/seabluescn/Blog_WebApi 一.概述 本篇介绍如 ...
- SDC_ETL融合数据产品白皮书
SDC_ETL融合数据产品白皮书 http://www.sefonsoft.com/?s=/home/pro/pdf/id/48.html
- BZOJ.3265.志愿者招募加强版(费用流SPFA)
题目链接 见上题. 每类志愿者可能是若干段,不满足那个...全幺模矩阵(全单位模矩阵)的条件,所以线性规划可能存在非整数解. 于是就可以用费用流水过去顺便拿个rank2 233. //20704kb ...