Welcome 微信登录

首页 / 数据库 / MySQL / Oracle 行转列 的写法

Oracle 行转列 的写法:/*DROP TABLE FOO;*//**创建一张演示的表**/CREATE TABLE FOO (    BBBID NUMBER(2),       --主键    DEPID NUMBER(2),      --单位编号    AAC006 VARCHAR2(1)  --性别  1男  2女  0未知    CONSTRAINT CK_AAC006 CHECK (AAC006 = "1" OR AAC006 ="2" OR AAC006 ="0"));/**插入用于测试的数据**/INSERT INTO FOO VALUES(1,1,"1");INSERT INTO FOO VALUES(2,1,"0");INSERT INTO FOO VALUES(3,1,"2");INSERT INTO FOO VALUES(4,1,"2");INSERT INTO FOO VALUES(5,2,"1");INSERT INTO FOO VALUES(6,2,"0");INSERT INTO FOO VALUES(7,2,"2");INSERT INTO FOO VALUES(8,2,"2");INSERT INTO FOO VALUES(9,3,"2");INSERT INTO FOO VALUES(10,3,"2");INSERT INTO FOO VALUES(11,3,"2");/**目标:对该表进行行转列,要得到如下结果集:depid 男 女 未知1      1   1  22      1   1  23      0   0  3*//**原始的数据**/SELECT * FROM FOO;/**按照性别码表取值,将FOO.AAC006转化为3列之后的值**/SELECT DEPID,    DECODE(AAC006,"0",1,0) "男",    DECODE(AAC006,"1",1,0) "女",    DECODE(AAC006,"2",1,0) "未知" FROM  FOO; /**在上一个结果集上进行加工,就得到行转列的结果!**/ SELECT DEPID,    SUM(DECODE(AAC006,"0",1,0)) "男",    SUM(DECODE(AAC006,"1",1,0)) "女",    SUM(DECODE(AAC006,"2",1,0)) "未知" FROM  FOO GROUP BY DEPID;
 /** 总结(czw  20120624): 行转列,其实就是将某一个字段,按照码值拆分为若干个字段,最后通过聚集函数得到相应的值。 **/Oracle 一行转多行在Oracle SQL语句中,单引号和双引号的使用相关资讯      oracle数据库教程 
  • Oracle raw数据类型介绍  (01/29/2013 10:05:53)
  • 监听器注册与ORA-12514 错误分析  (11/13/2012 14:30:08)
  • Oracle SQL的cursor理解  (11/13/2012 14:16:17)
  • Oracle 如何强制刷新Buffer Cache  (01/29/2013 10:02:46)
  • dblink致Oracle库的SCN变成两库的  (11/13/2012 14:24:41)
  • Linux操作系统下完全删除Oracle数  (11/13/2012 08:25:52)
本文评论 查看全部评论 (0)
表情: 姓名: 字数