zoukankan      html  css  js  c++  java
  • mysql实现行转列功能

    实现从图一转行成图二的功能:

    图一:

    图二:

    建表语句:

    CREATE TABLE `t_user_score` (
    `id`  int(11) NOT NULL AUTO_INCREMENT COMMENT '主键' ,
    `cname`  varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ,
    `cource`  varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ,
    `score`  int(11) NULL DEFAULT NULL ,
    PRIMARY KEY (`id`)
    )
    ENGINE=InnoDB
    DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci
    ;

    插入测试数据:

    INSERT INTO `coco_test`.`t_user_score` ( `cname`, `cource`, `score`) VALUES ( '小许', '语文', '90');
    INSERT INTO `coco_test`.`t_user_score` ( `cname`, `cource`, `score`) VALUES ( '小许', '数学', '99');
    INSERT INTO `coco_test`.`t_user_score` ( `cname`, `cource`, `score`) VALUES ( '小许', '英语', '88');
    INSERT INTO `coco_test`.`t_user_score` ( `cname`, `cource`, `score`) VALUES ( '小张', '语文', '87');
    INSERT INTO `coco_test`.`t_user_score` ( `cname`, `cource`, `score`) VALUES ( '小张', '数学', '93');
    INSERT INTO `coco_test`.`t_user_score` ( `cname`, `cource`, `score`) VALUES ( '小张', '英语', '78');

    实现sql:

    -- 行转列
    SELECT cname ,
        MAX(CASE cource WHEN '数学' THEN score ELSE 0 END ) 数学,
        MAX(CASE cource WHEN '语文' THEN score ELSE 0 END ) 语文,
        MAX(CASE cource WHEN '英语' THEN score ELSE 0 END ) 英语
    FROM t_user_score
    GROUP BY cname;
  • 相关阅读:
    79. 滑动窗口的最大值
    78. 左旋转字符串
    77. 翻转单词顺序
    76. 和为S的连续正数序列
    75. 和为S的两个数字
    innodb 锁机制
    MVCC
    linux查看状态命令
    design pattern 资料整理
    mysql资料汇总
  • 原文地址:https://www.cnblogs.com/cocoxu1992/p/11009040.html
Copyright © 2011-2022 走看看