`
zzx0421
  • 浏览: 98969 次
  • 性别: Icon_minigender_1
  • 来自: 株洲/深圳
社区版块
存档分类
最新评论

Oracle SQL行列转换示例

阅读更多
表ttt有三个字段
  seq --序列
  jcxm --检查项目
  zhi --值
  
  数据分别如下:
  seq   jcxm     zhi
  -------   --------     --------
  11     1    0.50
  11     2    0.21
  11     3    0.25
  12     1    0.24
  12     2    0.30
  12     3    0.22
  
  实现功能  创建视图时移动行值为列值
  
  create view v_view1
  as
  select seq,
  sum(decode(jcxm,1, zhi)) 检测项目1,
  sum(decode(jcxm,2, zhi)) 检测项目2,
  sum(decode(jcxm,3, zhi)) 检测项目3
  from ttt
  group by seq;
  
  序号 检测项目1  检测项目2  检测项目3
  11     0.50    0.21     0.25
  12     0.24    0.30     0.22
  
  技巧:  用THEN中的0和1来进行统计(SUM)
  
  jcxm  zhi
  ----  ----
  a      1
  b      1
  a      3
  d      2
  e      4
  f      5
  a      5
  d      3
  d      6
  b      5
  c      4
  b      3
  求他的zhi既是1,也是3,也是5的jcxm
  方法一
  select jcxm
  from ttt
  group by jcxm
  having sum(decode(zhi,1,-1,3,-1,5,-1,0)) = -3
  方法二
  select jcxm from ttt
  group by jcxm having (sign(sum(decode(zhi,1,-1,0)))+
  sign(sum(decode(zhi,3,-1,0)))+sign(sum(decode(zhi,5,-1,0)))<=-3);
  
  ----------
  a
  b
  说明:
  sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1
  所以可以用sign和decode来完成比较字段大小来区某个字段
  select decode(sign(字段1-字段2),-1,字段3,字段4) from dual;
  
  sign是一个对于写分析SQL有很强大的功能
  下面我对sign进行一些总结:
  但属性student取0和1以外的值,或者student取两个以上的标法值,问题就不会这么简单了
  解决办法就是特征函数(abs(),sign())
  
  常用的特征算法
  [A=B]=1-abs(sign(A-B))
  [A!=B]=abs(sign(A-B))
  [A<B]=1-sign(1+sign(A-B)) 不能用-sign(A-B):因为如果不满足A  [A<=B]=sign(1-sign(A-B))
  [A>B]=1-sign(1-sign(A-B))
  [A>=B]=sign(1+sign(A-B)))
  [NOTα]=1-d [α]
  [αANDb ]=d [α]*d [b ] (6)
  [αOR b ]=sign(d [α]+d [b ])
  
  例如:
  A<B             Decode( Sign(A-B), -1, 1, 0 )
  A<=B             Decode( Sign(A-B), 1, 0, 1 )
  A>B             Decode( Sign(A-B), 1, 1, 0 )
  A>=B             Decode( Sign(A-B), -1, 0, 1 )
  A=B             Decode( A, B, 1, 0 )
  A between B and C   Decode( Sign(A-B), -1, 0, Decode(Sign(A-C), 1, 0, 1 ))
  A is null            Decode(A,null,1,0)
  A is not null         Decode(A,null,0,1)     A in (B1,B2,...,Bn) Decode(A,B1,1,B2,1,...,Bn,1,0)
  nor LogA          Decode( LogA, 0, 1, 0 )       (1-Sign(LogA))
  LogA and LogB      LogA * LogB
  LogA or LogB       LogA + LogB
  LogA xor LogB      Decode(Sign(LogA),Sign(LogB),0,1)
  Mod(Sign(LogA),Sign(LogB),2
  
  >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  
  另外一个关于成绩的分析例子
  
  SELECT
  SUM(CASE WHEN cj <60 THEN 1 ELSE 0 END) as "not passed",
  SUM(CASE WHEN cj BETWEEN 60 AND 79 THEN 1 ELSE 0 END) as "passed",
  SUM(CASE WHEN cj BETWEEN 80 AND 89 THEN 1 ELSE 0 END) as "good",
  SUM(CASE WHEN cj >=90 THEN 1 ELSE 0 END) as "Excellent"
  FROM cjtable;
  
  decode用法2
  表、视图结构转化
  现有一个商品销售表sale,表结构为:
  month    char(6)      --月份
  sell    number(10,2)    --月销售金额
  
  现有数据为:
  200001  1000
  200002  1100
  200003  1200
  200004  1300
  200005  1400
  200006  1500
  200007  1600
  200101  1100
  200202  1200
  200301  1300
  
  想要转化为以下结构的数据:
  year   char(4)        --年份
  ------------  ---------------------
  month1  number(10,2)   --1月销售金额
  month2  number(10,2)   --2月销售金额
  month3  number(10,2)   --3月销售金额
  month4  number(10,2)   --4月销售金额
  month5  number(10,2)   --5月销售金额
  month6  number(10,2)   --6月销售金额
  month7  number(10,2)   --7月销售金额
  month8  number(10,2)   --8月销售金额
  month9  number(10,2)   --9月销售金额
  month10  number(10,2)   --10月销售金额
  month11  number(10,2)   --11月销售金额
  month12  number(10,2)   --12月销售金额
  
  结构转化的SQL语句为:
  create or replace view
  v_sale(year,month1,month2,month3,month4,month5,month6,month7,month8,month9,month10,month11,month12)
  as
  select
  substrb(month,1,4),
  sum(decode(substrb(month,5,2),'01',sell,0)),
  sum(decode(substrb(month,5,2),'02',sell,0)),
  sum(decode(substrb(month,5,2),'03',sell,0)),
  sum(decode(substrb(month,5,2),'04',sell,0)),
  sum(decode(substrb(month,5,2),'05',sell,0)),
  sum(decode(substrb(month,5,2),'06',sell,0)),
  sum(decode(substrb(month,5,2),'07',sell,0)),
  sum(decode(substrb(month,5,2),'08',sell,0)),
  sum(decode(substrb(month,5,2),'09',sell,0)),
  sum(decode(substrb(month,5,2),'10',sell,0)),
  sum(decode(substrb(month,5,2),'11',sell,0)),
  sum(decode(substrb(month,5,2),'12',sell,0))
  from sale
  group by substrb(month,1,4);
  
  体会:要用decode /group by/ order by/sign/sum来实现不同报表的生成
  >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
  CASE应用
  
  1    1    部门a    800    男
  2    2    部门b    900    女
  3    3    部门a    400    男
  4    4    部门d    1400    女
  5    5    部门e    1200    男
  6    6    部门f    500    男
  7    7    部门a    300    女
  8    8    部门d    1000    男
  9    9    部门d    1230    女
  10    10    部门b    2000    女
  11    11    部门c    2000    男
  12    12    部门b    1200    男
  
  SELECT jcxm as 部门,COUNT(seq) as 人数,
  SUM(CASE SEX WHEN 1 THEN 1 ELSE 0 END) as 男,
  SUM(CASE SEX WHEN 2 THEN 1 ELSE 0 END) as 女,
  SUM(CASE SIGN(zhi-800) WHEN -1 THEN 1 ELSE 0 END) as 小于800元,
  SUM((CASE SIGN(zhi-800)*SIGN(zhi-1000)          /*用*来实现<和>功能*/
  WHEN -1 THEN 1 ELSE 0 END)+(CASE zhi
  WHEN 800 THEN 1 ELSE 0 END)) as 从800至999,     /*注意别名不能以数字开头*/
  SUM((CASE SIGN(zhi-1000)*SIGN(zhi-1200)
  WHEN -1 THEN 1 ELSE 0 END)+(CASE zhi
  WHEN 1000 THEN 1 ELSE 0 END)) as 从1000元至1199元,
  SUM((CASE SIGN(zhi-1200) WHEN 1 THEN 1 ELSE 0 END)
  +(CASE zhi WHEN 1200 THEN 1 ELSE 0 END)) as 大于1200元
  FroM ttt
  GROUP BY jcxm
  
  部门名 人数  男  女  小于800元 从800至999 从1000元至1199元  大于1200元
  部门a 3    2  1    2    1      0        0
  部门b 3    1  2    0    1      0        2
  部门c 1    1  0    0    0      0        1
  部门d 3    1  2    0    0      1        2
  部门e 1    1  0    0    0      0        1
  部门f 1    1  0    1    0      0        0
分享到:
评论

相关推荐

    oracle sql 行列转换

    下面,我们将详细解析如何在Oracle SQL中实现行列转换,并通过具体示例来加深理解。 ### Oracle SQL中的行列转换方法 #### 1. 使用CASE语句 CASE语句是Oracle SQL中实现条件判断的一种方式,它可以根据不同的条件...

    Oracle行列转换

    通过下载提供的`Oracle补充内容_行列转换.sql`文件,你可以看到具体的SQL示例和实际操作,这将帮助你更好地理解和掌握Oracle的行列转换技巧。在实践中,理解并熟练运用这些技术,将有助于你更有效地处理和展示数据,...

    Oracle SQLServer行列转换

    ### Oracle SQLServer 行列转换知识点详解 #### 一、SQLServer 行转列方法 在SQLServer中,实现行转列的操作有两种主要方法:一种是利用`CASE...WHEN`语句配合`GROUP BY`聚合函数的方式;另一种是通过`PIVOT`操作...

    Oracle中SQL语句行列之间相互转换

    在Oracle数据库中,有时我们需要将表格中的行转换为列或将列转换为行,这种操作被称为行列转换。这种转换对于数据分析、报表制作等场景非常有用。本文将详细介绍Oracle中如何进行行列转换,并提供实际的例子。 ####...

    oracle行列转换实例

    【Oracle 行列转换实例】 在数据库管理中,有时我们需要将数据表的行与列进行转换,以便于数据分析和报表展示。Oracle 提供了一种高效的方法,即使用分析函数来实现这种行列转换。分析函数主要设计用于处理累计计算...

    oracle行列转换总结

    本文将深入探讨Oracle中实现行列转换的几种方法,包括使用`UNION ALL`、`MODEL`子句以及集合类型(`collections`),并提供具体的示例来帮助理解。 ### 1. 使用`UNION ALL`进行行列转换 `UNION ALL`是一种简单直接的...

    oracle行列转换

    在Oracle数据库中,进行行列转换是一项常见的数据处理需求,尤其当数据存储格式与最终报告或分析所需的格式不一致时。这种转换技术可以帮助我们将表格中的行数据转换为列数据,反之亦然,从而使得数据能够更好地适应...

    通过SQL语句实现行列转换的几种方法

    ### 通过SQL语句实现行列转换的几种方法 在日常工作中,我们经常需要处理的数据结构并不总是按照我们期望的方式组织的。特别是在制作自定义报表或进行产品开发时,经常会遇到需要将数据从一种布局转换到另一种布局...

    oracle行列转换的例子

    通过上述示例,我们可以看到在Oracle数据库中实现行列转换的方法是可行且有效的。这种方法不仅可以提高数据展示的清晰度,还能够在一定程度上简化复杂的数据查询任务。然而,在实际应用中还需要注意动态SQL所带来的...

    ORACLE 行列转换

    在Oracle数据库中,行列转换是一种常见的数据操作需求,主要用于改变数据的展示格式,使得数据能够更好地适应特定的分析或报告需求。本文将详细介绍如何在Oracle中实现行转列(即行列转换的一种)以及列转行的操作,...

    Oracle 行列转换总结

    ### Oracle 行列转换知识点详解 #### 一、概述 在数据库操作中,行列转换是一项非常实用的功能,尤其是在处理报表数据或需要特定格式输出时。本文档将详细讲解Oracle数据库中的行列转换方法,并通过具体实例来说明...

    Oracle行列转换_总结

    ### Oracle 行列转换知识点详解 #### 一、概述 在数据库操作中,有时需要将数据从行格式转换为列格式或反之亦然,这种需求通常被称为“行列转换”。Oracle 提供了多种方法来实现这样的转换,适用于不同的场景。本文...

    Oracle实现行列转换的方法分析

    总之,Oracle提供了多种方式进行行列转换,包括使用DECODE、分析函数、PL/SQL函数以及动态SQL等。选择哪种方法取决于数据的特性、需求的复杂性以及对性能的影响。在实际应用中,应结合具体情况灵活运用这些技术,以...

    sql行列转换[借鉴].pdf

    在SQL中,行列转换是一种常见的数据操作,用于将表格数据从行格式转换为列格式,或者反之。在给定的PDF文件中,涉及到的具体知识点主要包括以下几个方面: 1. **CASE语句**:在SQL查询中,`CASE`语句常用于进行条件...

    一道java面试题 行列转换

    本篇文章将通过一个具体的Java面试题目,详细介绍如何在Oracle和SQL Server两种数据库环境下实现行列转换,并给出具体的示例代码。 #### 二、需求分析与设计 假设我们有一个成绩表`sc`,表结构如下: - `sid`: ...

    ORACLE 10g 的行列转换(学生科目成绩)测试题

    在Oracle数据库管理中,数据处理有时需要将行数据转换为列数据,或者将列数据转换为行数据,这种操作被称为行列转换。Oracle 10g 提供了多种方法来实现这种转换,包括使用PIVOT和UNPIVOT操作,以及自定义SQL查询等。...

    sql经典 oracle的查询结果的行列互换

    这种操作通常被称为“行列转换”或“行列互换”。本文将详细介绍如何在Oracle数据库中实现这样的转换,并通过具体的示例来演示两种常用的方法:`UNION` 和 `CASE` 语句。 #### 二、背景知识 在开始之前,让我们先...

Global site tag (gtag.js) - Google Analytics