Mysql或者Hive数据行变成列

对于mysql /  hive 再进行统计的时候如果需要行变成列,可以使用函数

CASE 字段a WHEN 值b THEN c [WHEN d THEN e]* [ELSE f] END

当字段a=值b时,返回c(如果是字段的话则代表该字段的值,也可以是一个固定值 加单引号就可以);当a=d时,返回e,否则返回f。

如:

数据表结构:(举例说明,id有重复的)

select id
,sum(CASE action when 'article' then count else 0 end) as article
,sum(CASE action when 'user_comment' then count else 0 end) as user_comment
,sum(CASE action when 'profile' then count else 0 end) as `profile`
,sum(CASE action when 'user_follow' then count else 0 end) as user_follow
,sum(CASE action when 'user_repost' then count else 0 end) as user_repost
,sum(CASE action when 'user_timeline' then count else 0 end) as user_timeline
from t_stat_user_action where stat_time='20150725' and id='1820485935'
group by id

结果为

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-12-17 15:02:24

Mysql或者Hive数据行变成列的相关文章

freemarker导出word——让表格数据行数 列数自动变化

行数.列数变化只需定义一个List<List<T>> freemarker遍历的话,只需要使用freemarker的标记性语言<#list report.qc_third_agentTable as  table2_tr>遍历即可,如图 实现的效果 freemarker导出word--让表格数据行数 列数自动变化,布布扣,bubuko.com

数据行转列的应用(json数据源)

开发项目时有时会遇到将数据的行列进行转换.今天逛园子是看到一个很不错的方法.不需要在数据库中对数据进行行列转换,将数据集合转换长json格式使用如下代码即可. <script> $(document).ready(function () { var jsonData = [ { time: '2014-07-08', name: '电费', value: 120 }, { time: '2014-07-09', name: '电费', value: 66 }, { time: '2014-07

数据行转列实例

在系统开发中常常遇到进行数据的统计,并将数据行转列的情景,例如表中的表示.但是在数据库中呈现出来的数据往往是横行的样式.这就需要一个转换.转换的方式有两种方式.1.利用cross join去进行转换.2.利用case when函数去转换. 数据库查询出的结果: 张三 170 李四 90 王五 180 需要数据行转列后的结果: 张三 李四 王五 170 90 180 需求: DEMO中就是简单的统计学生的总成绩.将统计结果进行行转列显示. 需要的表和数据: T_STUDENTINFO表 CREAT

JSON数据行转列的应用

背景 先说说为什么要弄什么行转列. 时间 类别 费用 2014-07-08 电费 120 2014-07-08      水费 23 2014-07-09 电费 44 2014-07-09 水费 77 2014-07-10 电费 45 2014-07-10 水费 21 2014-07-11 电费 34 2014-07-11 水费 27 费劲的弄出表格,才发现,弄成了每天的水电费,不过是测试数据,不要在意这些细节. 很多时候我们就通过sql语句在数据库中查询到如上数据,那么展现到页面的时候,势必要

Sql server 中将数据行转列列转行(二)

老规矩,先弄一波测试数据,数据填充代码没有什么意义,先折叠起来: /* 第一步:创建临时表结构 */ CREATE TABLE #Student --创建临时表 ( StuName nvarchar(20), --学生名称 Chinese int, Math int, English int ) DROP TABLE #Student --删除临时表 SELECT * FROM #Student --查询所有数据 INSERT INTO #Student(StuName,Chinese,Math

MYSQL开发技巧之行转列和列转行

行转列--两种方法第一种方法:行转列我们通常是使用交叉连接和子查询的方式做到,比如下面的例子,查询每个name的对应id的和mysql> select * from user; +----+------+ | id | name | +----+------+ | 1 | a | | 2 | b | | 3 | c | | 4 | d | | 5 | a | | 6 | a | | 7 | c | | 8 | d | +----+------+ 我们用分组查询能得到每个name的id的和,但是是

Sql server 中将数据行转列列转行(一)

在做一些数据分析与数据展示时,经常会遇到行转列,列转行的需求,今天就来总结下: 在开始之前,先来创建一个临时表,并且写入一些测试数据: /* 第一步:创建临时表结构 */ CREATE TABLE #Student --创建临时表 ( StuName nvarchar(20), --学生名称 StuSubject nvarchar(20),--考试科目 StuScore int --考试成绩 ) DROP TABLE #Student --删除临时表 SELECT * FROM #Student

Oracle数据 行转列

记录一段行转列SQL代码: select cs.standard_id,cs.area_code,cs.exu_dept, regexp_substr(exu_dept, '[^,]+', 1, level) as dept_id from ca_stand_exu_dept cs connect by id = prior id and instr(exu_dept||',', ',', 1, level) > 0 and prior dbms_random.value is not null

C#读txt文件并写入二维数组中(txt数据行,列未知)

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.IO; namespace 二维数组 { class Program { static void Main(string[] args) { int row = 0;//行 int col = 0;//lie FileStream fs; string path = @"C:\Documents an