zoukankan      html  css  js  c++  java
  • 数据库之横表转纵表、纵表转横表

    /*横表变纵表或纵表变横表

    成绩表如下
    Name Course Grade
    张三 语文 95
    张三 数学 90
    张三 英语 89
    李四 语文 92
    李四 数学 88
    李四 英语 97
    变成

    姓名 语文 数学 英语
    张三 95 90 89
    李四 92 88 97
    */

    --纵表转横表
        create table biao
    (
    PName varchar(10),
    PCourse  varchar (10),
    PGrade int
    ) 
    go
     insert into biao values('张三','语文','95')  
     insert into biao values('张三','数学','90')  
     insert into biao values('张三','英语','89')  
     insert into biao values('李四','语文','92')  
     insert into biao values('李四','数学','88')  
     insert into biao values('李四','英语','97')  
     select* from biao
     --下面输入转换方式
     select PName ,
     SUM(case PCourse when '语文'then PGrade else 0 end)as 语文,
     SUM(case PCourse when '数学'then PGrade else 0 end)as 数学,
     SUM(case PCourse when '英语'then PGrade else 0 end)as 英语
     from  biao
     group by PName

    --横表转纵表
    --例2创建表2
     create table biao1
    (
    姓名 varchar(20),
    语文 int,
    数学 int,
    英语 int
    ) 
    go
     insert into biao1 values('张三',95,90,89)  
     insert into biao1 values('李四',92,88,97)
     select * from biao1
    --下面输入转换方式
     select * from biao1
     select 姓名 ,'语文' as 课程,语文 as 成绩 from biao1 union all
     select 姓名,'数学'as 课程,数学 as 成绩 from biao1 union all
     select 姓名,'英语'as 课程,英语 as 成绩 from biao1
     order by 姓名 desc

  • 相关阅读:
    gitlab安装笔记二_Centos7配置163yum源
    gitlab安装笔记一_虚拟机中安装Centos7
    初篇:我与Linux
    Redis分布式锁正确的实现方法
    MacOS从零开始搭建hexo博客
    docker服务编排--docker-compose
    多线程问题整理
    maven依赖范围
    linux打开文件数 too many open files 解决办法
    【数据结构】队列-数组模拟队列
  • 原文地址:https://www.cnblogs.com/franky2015/p/4675496.html
Copyright © 2011-2022 走看看