【SQL 学习】行列转换

简介:

SQL> conn system/yang as sysdba
已连接。
SQL> conn yang/yang
已连接。
SQL> create table change (name varchar(10),subject varchar2(20),grade int);
表已创建。
SQL> set timing on
SQL> insert into change values ('Jim','语文',100);
已创建 1 行。
已用时间:  00: 00: 00.00
SQL> insert into change values ('Jim','数学',90);
已创建 1 行。
已用时间:  00: 00: 00.03
SQL> insert into change values ('Jim','英语',99);
已创建 1 行。
已用时间:  00: 00: 00.00
SQL> insert into change values ('Lily','语文',80);
已创建 1 行。
已用时间:  00: 00: 00.01
SQL> insert into change values ('Lily','数学',90);
已创建 1 行。
已用时间:  00: 00: 00.00
SQL> insert into change values ('Lily','英语',94);
已创建 1 行。
已用时间:  00: 00: 00.01
SQL> commit;
提交完成。
已用时间:  00: 00: 00.03
SQL> select * from change;

NAME       SUBJECT                   GRADE                                     
---------- -------------------- ----------                                     
Jim        语文                        100                                     
Jim        数学                         90                                     
Jim        英语                         99                                     
Lily         语文                         80                                     
Lily         数学                         90                                     
Lily         英语                         94                                     
已选择6行。

SQL> select name as "姓名" ,
  2  sum(decode(subject,'语文',grade,NULL)) "语文",
  3  sum(decode(subject,'数学',grade,NULL)) "数学",
  4  sum(decode(subject,'英语',grade,NULL)) "英语"
  5  from change
  6  group by name;

姓名             语文       数学       英语                                    
---------- ---------- ---------- ----------                                    
Lily               80         90         94                                    
Jim            100         90         99                                    
已用时间:  00: 00: 00.01

相关文章
|
2月前
|
SQL 存储 关系型数据库
【MySQL基础篇】全面学习总结SQL语法、DataGrip安装教程
本文详细介绍了MySQL中的SQL语法,包括数据定义(DDL)、数据操作(DML)、数据查询(DQL)和数据控制(DCL)四个主要部分。内容涵盖了创建、修改和删除数据库、表以及表字段的操作,以及通过图形化工具DataGrip进行数据库管理和查询。此外,还讲解了数据的增、删、改、查操作,以及查询语句的条件、聚合函数、分组、排序和分页等知识点。
【MySQL基础篇】全面学习总结SQL语法、DataGrip安装教程
|
3月前
|
SQL 安全 前端开发
Web学习_SQL注入_联合查询注入
联合查询注入是一种强大的SQL注入攻击方式,攻击者可以通过 `UNION`语句合并多个查询的结果,从而获取敏感信息。防御SQL注入需要多层次的措施,包括使用预处理语句和参数化查询、输入验证和过滤、最小权限原则、隐藏错误信息以及使用Web应用防火墙。通过这些措施,可以有效地提高Web应用程序的安全性,防止SQL注入攻击。
97 2
|
8月前
|
SQL 存储 程序员
SQL查询的一些基本知识和学习指导
【6月更文挑战第17天】SQL查询核心包括基础选择、连接(JOIN)、子查询、聚合函数与GROUP BY、模糊匹配(LIKE)、分页与排序。JOIN操作连接多表,GROUP BY配合聚合函数做统计,LIKE用于模糊搜索。理解存储过程、触发器及自动增长列等进阶概念,通过实践提升SQL技能。
113 2
|
4月前
|
SQL 存储 数据库
SQL学习一:ACID四个特性,CURD基本操作,常用关键字,常用聚合函数,五个约束,综合题
这篇文章是关于SQL基础知识的全面介绍,包括ACID特性、CURD操作、常用关键字、聚合函数、约束以及索引的创建和使用,并通过综合题目来巩固学习。
97 1
|
6月前
|
SQL 存储 关系型数据库
PostgreSQL核心之SQL基础学习
PostgreSQL核心之SQL基础学习
74 3
|
8月前
|
SQL 存储 Java
SQL数据库学习指南:从基础到高级
SQL数据库学习指南:从基础到高级
|
7月前
|
SQL 存储 关系型数据库
关系型数据库SQL Server学习
【7月更文挑战第4天】
106 2
|
8月前
|
SQL 数据库
零基础学习数据库SQL语句之操作表中数据的DML语句
零基础学习数据库SQL语句之操作表中数据的DML语句
78 0
零基础学习数据库SQL语句之操作表中数据的DML语句
|
8月前
|
SQL 存储 关系型数据库
【数据库】SQL零基础入门学习
【数据库】SQL零基础入门学习
84 3
|
8月前
|
SQL 存储 关系型数据库
sql学习数据库
SQL(Structured Query Language)是用于管理关系型数据库的标准编程语言。学习SQL数据库涉及理解数据库的基本概念、SQL语言的结构和语法,以及如何使用SQL来查询、插入、更新