• 数据库之横表转纵表、纵表转横表


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

    成绩表如下
    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

  • 相关阅读:
    WordPress让文本小工具支持简码
    修改WordPress后台登录地址,提高安全性
    WordPress用键盘左右方向键来查看上一篇和下一篇文章
    Git 补丁操作
    Git 标签操作
    Git 修正错误
    Git 删除操作
    Git 重命名操作
    Git 移动操作
    Git 藏匿操作
  • 原文地址:https://www.cnblogs.com/franky2015/p/4675496.html
Copyright © 2020-2023  润新知