频道栏目
首页 > 数据库 > Oracle > 正文
ORACLE行转列的写法
2012-06-27 10:33:23           
收藏   我要投稿

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')

);  www.2cto.com  

/**插入用于测试的数据**/

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  www.2cto.com  

      1   1

  2

2

      1   1

  2

3

      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;  www.2cto.com  

 /**在上一个结果集上进行加工,就得到行转列的结果!**/

 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):

 行转列,其实就是将某一个字段,按照码值拆分为若干个字段,最后通过聚集函数得到相应的值。

 **/

 

 

作者 ziwen00

点击复制链接 与好友分享!回本站首页
相关TAG标签 写法
上一篇:密码文件的恢复_EM登录失败的解决
下一篇:在ORACLE SQL语句中,单引号和双引号的使用
相关文章
图文推荐
点击排行

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站