1103简单SQL 行转列思路
转自http://www.cnblogs.com/lhj588/p/3315876.html
-- 经典行列转化
DROP TABLE IF EXISTS TabName;
CREATE TABLE TabName (
Id INT(11) NOT NULL AUTO_INCREMENT,
NAME VARCHAR(20) DEFAULT NULL,
DATE DATE DEFAULT NULL,
Scount INT(11) DEFAULT NULL,
PRIMARY KEY (Id)
) ENGINE=INNODB DEFAULT CHARSET=utf8;
INSERT INTO TabName VALUES ('1', '小说', '2013-09-01', '10000');
INSERT INTO TabName VALUES ('2', '微信', '2013-09-01', '20000');
INSERT INTO TabName VALUES ('3', '小说', '2013-09-02', '30000');
INSERT INTO TabName VALUES ('4', '微信', '2013-09-02', '35000');
INSERT INTO TabName VALUES ('5', '小说', '2013-09-03', '31000');
INSERT INTO TabName VALUES ('6', '微信', '2013-09-03', '36000');
INSERT INTO TabName VALUES ('7', '小说', '2013-09-04', '35000');
INSERT INTO TabName VALUES ('8', '微信', '2013-09-04', '38000');
INSERT INTO TabName VALUES ('9', '小说', '2013-09-01', '10');
SELECT * FROM TabName;
-- 第零种 列表模式
ID NAME DATE SCOUNT
1 小说 '2013-9-1' 1000
-- 第一种 列表统计模式
SELECT
NAME,DATE,SUM(scount)
FROM TabName
GROUP BY NAME,DATE
-- 第二种 列转为行
DATE 小说 微信
'2013-09-01' 10000 20000
SELECT
DATE,
SUM(CASE WHEN NAME='小说' THEN Scount ELSE 0 END)AS '小说',
SUM(CASE WHEN NAME='微信' THEN Scount ELSE 0 END)AS '微信'
FROM TabName
GROUP BY DATE;
-- 第三种 行转为列
SELECT DATE, GROUP_CONCAT(NAME,'总量:',Scount) AS b_str FROM TabName
GROUP BY DATE;
SELECT DATE,NAME, GROUP_CONCAT(NAME,'总量:',Scount) AS b_str FROM TabName
GROUP BY DATE ,NAME;
1103简单SQL 行转列思路的更多相关文章
- Sql 行转列问题总结
行转列问题总结 1.行转列 ---1.最简单的行转列/* 问题:假设有张学生成绩表(tb)如下:姓名 课程 分数张三 语文 74张三 数学 83张三 物理 93李四 语文 74李四 数学 84李四 物 ...
- SQL 行转列
---1.最简单的行转列/* 问题:假设有张学生成绩表(tb)如下:姓名 课程 分数张三 语文 74张三 数学 83张三 物理 93李四 语文 74李四 数学 84李四 物理 94 想变成(得到如下结 ...
- SQL行转列,列转行
SQL 行转列,列转行 行列转换在做报表分析时还是经常会遇到的,今天就说一下如何实现行列转换吧. 行列转换就是如下图所示两种展示形式的互相转换 行转列 假如我们有下表: SELECT * FROM s ...
- SQL 行转列和列转行
SQL 行转列和列转行 行列互转,是一个经常遇到的需求.实现的方法,有case when方式和2005之后的内置pivot和unpivot方法来实现. 在读了技术内幕那一节后,虽说这些解决方案早就用过 ...
- Ms sql行转列。汇总
SQL行转列汇总 PIVOT 用于将列值旋转为列名(即行转列),在 SQL Server 2000可以用聚合函数配合CASE语句实现 PIVOT 的一般语法是:PIVOT(聚合函数(列) FOR 列 ...
- sql 行专列 列转行 普通行列转换
转载:http://www.cnblogs.com/newwind521/archive/2010/11/25/1887203.html sql 行专列 列转行 普通行列转换 /* 标题:普通行列转换 ...
- sql 行转列 PIVOT 列转行 UNPIVOT
原文:sql 行转列 PIVOT 列转行 UNPIVOT 一: 现有表一(t_table1),想转为表二(t_table2)的格式. 表一: 年 公司 收入 2013 公司1 12 2013 公司2 ...
- sql 行转列总结
原文:sql 行转列总结 PIVOT UNPIVOT的用法 PIVOT用于将列值旋转为列名(即行转列),在SQL Server 2000可以用聚合函数配合CASE语句实现 PIVOT的一般语法是:PI ...
- SQL行转列 (及EAV模型获取数据)
参考文章: http://www.williamsang.com/archives/1508.html 情景简介 学校里面记录成绩,每个人的选课不一样,而且以后会添加课程,所以不需要把所有课程当作列. ...
随机推荐
- linux原始套接字(2)-icmp请求与接收
一.概述 上一篇arp请求使用的是链路层的原始套接字.icmp封装在ip数据报里面,所以icmp请 ...
- position&containing block
一.包含块(Containing Block) 要讲position,首先就涉及到一个概念:包含块. 1.包含块介绍 包含块简单理解就是一个定位参考块,就是"大盒子里套小盒子"中那 ...
- css3 border-radius
前缀对应浏览器 前缀 浏览器 -webkit chrome和safari -moz firefox -ms IE -o opera border-radius: <style type=&quo ...
- BFC 小结
最近对一些基础知识进行了整理,下面是针对 BFC 的一些整理以及本人对 BFC 的一些理解. 1. 首先,什么是 BFC 呢? BFC,Block formatting context,直译为&quo ...
- Caffe 抽取CNN网络特征 Python
Caffe Python特征抽取 转载请注明出处,楼燚(yì)航的blog,http://www.cnblogs.com/louyihang-loves-baiyan/ Caffe大家一般用到的深度学 ...
- Zookeeper 监视(Watches) 简介(转)
Zookeeper C API 的声明和描述在 include/zookeeper.h 中可以找到,另外大部分的 Zookeeper C API 常量.结构体声明也在 zookeeper.h 中,如果 ...
- ACCP 结业考试
1) 在SQL Server 中,为数据库表建立索引能够(C ). 索引:是SQL SERVER编排数据的内部方法,是检索表中数据的直接通道 建立索引的作用:大大提高了数据库的检索速度,改善数据库性能 ...
- java问题小总结
1.在使用equals的时候,把 "".equals(name);放在左边 如果右边的没有初始化,可以避免出错. 2.对于 ObjectId id; 在mongodb里面对其进行 ...
- CSS3文本超出容器显示省略号之text-overflow属性
text-overflow:ellipsis; overflow:hidden; white-space:nowrap; 要想实现文本超出容器时显示省略号,上面3个属性必须同时搭配使用
- saltstack安装配置(halite)
saltstack官方提供了一个简单的web UI--halite.但是给出的安装配置方法实在没法实现,在网上找了几篇博客,见文章末尾的参考链接,可以用起来了.但是功能有点简单.这篇文章记录安装配置h ...