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

  • 相关阅读:
    图片上传
    中间件
    放大镜
    JQ编写楼层效果
    AJAX,PHP,前端简单交互制作输入框效果
    AJAX中使用post,get接收发送数据的区别
    PHP内写css样式
    计算2个日期相差的月份
    react-相关技术栈之-dva/dynamic
    es6相关知识点
  • 原文地址:https://www.cnblogs.com/franky2015/p/4675496.html
Copyright © 2011-2022 走看看