用decode函数实现行变列

用decode函数实现行变列
----创建测试表
create table student_score(
name varchar2(20),
subject varchar2(20),
score number(4,1)
);
-----插入测试数据
insert into student_score (name,subject,score)values(‘张三‘,‘语文‘,78);
insert into student_score (name,subject,score)values(‘张三‘,‘数学‘,88);
insert into student_score (name,subject,score)values(‘张三‘,‘英语‘,98);
insert into student_score (name,subject,score)values(‘李四‘,‘语文‘,89);
insert into student_score (name,subject,score)values(‘李四‘,‘数学‘,76);
insert into student_score (name,subject,score)values(‘李四‘,‘英语‘,90);
insert into student_score (name,subject,score)values(‘王五‘,‘语文‘,99);
insert into student_score (name,subject,score)values(‘王五‘,‘数学‘,66);
insert into student_score (name,subject,score)values(‘王五‘,‘英语‘,91);
-----decode行转列
select name "姓名",
sum(decode(subject, ‘语文‘, nvl(score, 0), 0)) "语文",
sum(decode(subject, ‘数学‘, nvl(score, 0), 0)) "数学",
sum(decode(subject, ‘英语‘, nvl(score, 0), 0)) "英语"
from student_score
group by name;
------ case when 行转列
select name "姓名",
sum(case when subject=‘语文‘
then nvl(score,0)
else 0
end) "语文",
sum(case when subject=‘数学‘
then nvl(score,0)
else 0
end) "数学",
sum(case when subject=‘英语‘
then nvl(score,0)
else 0
end) "英语"
from student_score
group by name;收起

时间: 2024-10-12 22:17:26

用decode函数实现行变列的相关文章

GreenPlum之数组合并取交集及行变列、列变行函数

--1.利用INTERSECT关键字数组之间交集函数 CREATE OR REPLACE FUNCTION array_intersect(anyarray, anyarray) RETURNS anyarray AS $$ SELECT ARRAY( SELECT UNNEST($1) INTERSECT SELECT UNNEST($2)); $$ LANGUAGE SQL; select array_intersect(array[1,2,3],array[2,3,4]); --2.行变列

[MySQL] 行列转换变化各种方法实现总结(行变列报表统计、列变行数据记录统计等)

前言: mysql行列变化,最难的就是将多个列变成多行,使用的比较多的是统计学中行变列,列变行,没有找到现成的函数或者语句,所以自己写了存储过程,使用动态sql来实现,应用业务场景,用户每个月都有使用记录数录入一张表,一个月一个字段,所以表的字段是动态增长的,现在需要实时统计当前用户使用的总数量,如果你知道有多少个字段,那么可以用select c1+c2+c3+-. From tbname where tid='111';来实现,但是关键是这个都是动态的,所以在应用程序端来实现确实不适宜,可以放

sql与oracle中有关case和decode的用法(行转列)及比较(转

引: 为了举例说明,这里创建了一张成绩表,如下图所示: 比较: 1.sql中,这两个函数我们仅能使用case,代码及结果如下: select name,       case Subject          when '语文' then 1          when '数学' then 2          when '英语' then 3   --else 3       end  as '科目代码'   from Results 同样的,我们可以用case实现行转列,代码及结果如下: s

sql server存储过程分页,行变列

CREATE PROCEDURE [dbo].[PROC_GetPriviousAndNextDetailContent]@Index varchar(20),--表主键@Table varchar(100),--从哪个表获取数据@Columns varchar(100),--需要获取哪些字段@OrderStr varchar(100),--排序字段及方式@Where1    varchar(100),--row_number中的初步过滤条件@Where2 varchar(100)--当前要查询

mysql 行变列(多行变成一行/多行合并成一行/多行合并成多列/合并行)

数据库结构如图: 而我想让同一个人的不同成绩变成此人在这一行不同列上显示出来,此时分为2中展现: 第一种展现如图----[多行变一列](合并后的数据在同一列上): sql如下: select name ,group_concat(sore Separator ';') as score from stu group by name 第二种展现如图----[多行变多列](合并后的数据在不同列上): sql如下: SELECT name , MAX(CASE type WHEN '数学' THEN

SQL 行变列 列变行

--创建Table create table student(name varchar(50),course varchar(50),score int) insert into student values('張三','語文',80) insert into student values('張三','數學',76) insert into student values('張三','物理',90) insert into student values('李四','語文',73) insert i

Oracle 11g Pivot函数实现行转列

先上语法规范: SELECT .... FROM <table-expr> PIVOT ( aggregate-function(<column>) FOR <pivot-column> IN (<value1>, <value2>,..., <valuen>) ) AS <alias> WHERE ..... 通过一个例子说明其用法: select * from (select salary, department_id

oracle的wm_concat函数实现行转列

有以下数据 deptname phone username isboss 部门A 电话1 员工A 0 部门A 电话1 领导A 1 部门B 电话2 员工B 0 部门B 电话2 员工C 0 部门B 电话2 领导D 1 需要展示效果 deptname phone boss emp 部门A 电话1 领导A 员工A 部门B 电话2 领导D 员工B,员工C 因为是oracle10g的原因,所以使用了wm_concat函数,但对wm_concat结果长度有限制,超出会报ORA-22922:不存在的LOB值,这

行变列 拼接字符串 MSSQL 一个超级搞的问题

由数据 ThreeLevelSortID KeyWordID KeyWordName 2 142 key1 2 142 key2 3 143 key3 3 144 key4 得到数据大 ThreeLevelSortID KeyWordName 2 key1,key2 3 key3,key4 declare @tblTmp table (id int,ThreeLevelSortID int,KeyWordName nvarchar(max)) declare @tblTmpCount int i