Oracle笔记(十一) 建表、更新、查询综合练习

Oracle笔记(十一) 建表、更新、查询综合练习

有某个学生运动会比赛信息的数据库,保存了如下的表:

  • 运动员sporter(运动员编号sporterid,运动员姓名name,运动员性别sex,所属系号department)
  • 项目item(项目编号itemid,项目名称itemname,项目比赛地点location)
  • 成绩grade(运动员编号id,项目编号itemid,积分mark)

请用SQL语句完成如下功能:

1、  建表,并在相应字段上增加约束;

  • 定义各个表的主键和外键约束;
  • 运动员的姓名和所属系别不能为空;
  • 积分要第为空值,要么为6,4,2,0,分别代表第一,二,三名和其他名次的积分,注意名次可以有并列名次,后面的排名不往前提升,例如,如果有两个并列第一,则没有第二名。

2、  向表中插入指定的数据:

运动员(
         1001,李明,男,计算机系
         1002,张三,男,数学系
         1003,李四,男,计算机系
         1004,王二,男,物理系
         1005,李娜,女,心理系
         1006,孙丽,女,数学系)
项目(
         X001,男子五千米,一操场
         X002,男子标枪,一操场
         X003,男子跳远,二操场
         X004,女子跳高,二操场
         X005,女子三千米,三操场)
积分(
         1001,x001,6
         1002,x001,4
         1003,x001,2
         1004,x001,0
         1001,x003,4
         1002,x003,6
         1004,x003,2
         1005,x004,6
         1006,x004,4
         1003,x002,6
         1005,x002,4
         1006,x002,2
         1001,x002,0)

3、  完成如下的查询要求:

A、求出目前总积分最高的系名,及其积分。

B、找出在一操场进行比赛的各项目名称及其冠军的姓名。

C、找出参加了张三所参加的所有项目的其他同学的姓名。

D、经查张三因为使用了违禁药品,其成绩都记0分,请在数据库中作出相应修改。

E、经组委会协商,需要删除女子调高比赛项目。

一、建表

DROP TABLE grade PURGE;
DROP TABLE sporter PURGE;
DROP TABLE item PURGE;
CREATE TABLE sporter (
    sporterid NUMBER(4)     PRIMARY KEY,
    name                 VARCHAR2(20)         NOT NULL,
    sex            VARCHAR2(10)         CHECK (sex IN(‘男‘,‘女‘)),
    department     VARCHAR2(20)         NOT NULL
);
CREATE TABLE item (
    itemid                VARCHAR2(4)  PRIMARY KEY,
    itemname         VARCHAR2(20)         NOT NULL,
    location    VARCHAR2(20)         NOT NULL
);
CREATE TABLE grade (
    sporterid NUMBER(4)     REFERENCES sporter(sporterid) ON DELETE CASCADE,
    itemid                VARCHAR2(4)  REFERENCES item(itemid) ON DELETE CASCADE,
    mark                  NUMBER(1)     CHECK (mark IN (0,2,4,6))
);

而且在Oracle之中要考虑回收站的问题。

二、增加数据

1、  增加运动员数据:

INSERT INTO sporter(sporterid,name,sex,department) VALUES (1001,‘李明‘,‘男‘,‘计算机系‘);
INSERT INTO sporter(sporterid,name,sex,department) VALUES (1002,‘张三‘,‘男‘,‘数学系‘);
INSERT INTO sporter(sporterid,name,sex,department) VALUES (1003,‘李四‘,‘男‘,‘计算机系‘);
INSERT INTO sporter(sporterid,name,sex,department) VALUES (1004,‘王二‘,‘男‘,‘物理系‘);
INSERT INTO sporter(sporterid,name,sex,department) VALUES (1005,‘李娜‘,‘女‘,‘心理系‘);
INSERT INTO sporter(sporterid,name,sex,department) VALUES (1006,‘孙丽‘,‘女‘,‘数学系‘);

2、  增加项目数据

INSERT INTO item(itemid,itemname,location) VALUES (‘x001‘,‘男子五千米‘,‘一操场‘);
INSERT INTO item(itemid,itemname,location) VALUES (‘x002‘,‘男子标枪‘,‘一操场‘);
INSERT INTO item(itemid,itemname,location) VALUES (‘x003‘,‘男子跳远‘,‘二操场‘);
INSERT INTO item(itemid,itemname,location) VALUES (‘x004‘,‘女子跳高‘,‘二操场‘);
INSERT INTO item(itemid,itemname,location) VALUES (‘x005‘,‘女子三千米‘,‘三操场‘);

3、  增加运动员的项目成绩

INSERT INTO grade(sporterid,itemid,mark) VALUES (1001,‘x001‘,6);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1002,‘x001‘,4);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1003,‘x001‘,2);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1004,‘x001‘,0);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1001,‘x003‘,4);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1002,‘x003‘,6);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1004,‘x003‘,2);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1005,‘x004‘,6);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1006,‘x004‘,4);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1003,‘x002‘,6);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1005,‘x002‘,4);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1006,‘x002‘,2);
INSERT INTO grade(sporterid,itemid,mark) VALUES (1001,‘x002‘,0);

三、数据操作

1、  求出目前总积分最高的系名,及其积分。

1、确定所要使用的数据表:

  • sporter表:求出系名称;
  • grade表:找到积分;

2、确定已知的关联字段:sporter.sporterid=grade.sporterid;

第一步:将sporter表和grade表联合

SELECT s.department,g.mark
FROM sporter s,grade g
WHERE s.sporterid=g.sporterid;

第二步:以上是求出每个系针对于项目获得的积分,那么下面将以上的查询分组,按照系名称分组。

SELECT s.department,SUM(g.mark)
FROM sporter s,grade g
WHERE s.sporterid=g.sporterid
GROUP BY s.department;

此时已经知道各个系的成绩了,那么对于求出总积分最高的信息,有两种做法:

  • 做法一:不考虑相同积分的问题,所有的数据由高到低降序排列,取第一个数据。
SELECT * FROM (
    SELECT s.department,SUM(g.mark) sum
    FROM sporter s,grade g
    WHERE s.sporterid=g.sporterid
    GROUP BY s.department
    ORDER BY sum DESC)
WHERE ROWNUM=1;
  • 做法二:考虑相同积分的问题,则必须首先进行分组函数的嵌套,求出最高的积分是多少,而后再用此内容与之前的分组进行过滤。
SELECT s.department,SUM(g.mark) sum
FROM sporter s,grade g
WHERE s.sporterid=g.sporterid
GROUP BY s.department
HAVING SUM(g.mark)=(
    SELECT MAX(SUM(g.mark)) sum
    FROM sporter s,grade g
    WHERE s.sporterid=g.sporterid
    GROUP BY s.department);

2、  找出在一操场进行比赛的各项目名称及其冠军的姓名。

1、确定所要使用的数据表:

  • sporter表:运动员的姓名;
  • item表:项目名称;
  • grade表:冠军的信息依靠成绩计算;

2、确定已知的关联字段:

  • 运动员和成绩:sporter.sporterid=grade.sporterid;
  • 项目和成绩:item.itemid=grade.itemid;

第一步:确定一操场进行的项目的ID

SELECT itemid FROM item WHERE location=‘一操场‘;

第二步:求出冠军的成绩,因为各个项目有各个项目的冠军分数

SELECT i.itemid,MAX(g.mark) max
FROM item i,grade g
WHERE i.location=‘一操场‘ AND i.itemid=g.itemid
GROUP BY i.itemid;

第三步:要根据这个成绩,找到对应的运动员姓名

SELECT s.name,g.itemid,temp.max
FROM sporter s,grade g,(
    SELECT i.itemid iid,MAX(g.mark) max
    FROM item i,grade g
    WHERE i.location=‘一操场‘ AND i.itemid=g.itemid
    GROUP BY i.itemid) temp
WHERE s.sporterid=g.sporterid AND temp.iid=g.itemid AND g.mark=temp.max;

第四步:找到项目名称,引入item表

SELECT s.name,g.itemid,temp.max,i.itemname
FROM sporter s,grade g,(
SELECT i.itemid iid,MAX(g.mark) max
FROM item i,grade g
WHERE i.location=‘一操场‘ AND i.itemid=g.itemid
GROUP BY i.itemid) temp,item i
WHERE s.sporterid=g.sporterid AND temp.iid=g.itemid AND g.mark=temp.max
AND g.itemid=i.itemid AND temp.iid=i.itemid;

3、  找出参加了张三所参加的所有项目的其他同学的姓名。

1、确定所要使用的数据表:

  • sporter表:张三的运动员ID;
  • grade表:根据它找到项目的ID;
  • sporterid:根据grade表和之前的sporter表确定出的项目ID,找到运动员的编号及姓名;

2、确定已知的关联字段:sporter.sporterid=grade.sporterid;

第一步:确定张三的运动员编号

SELECT s.sporterid
FROM sporter s
WHERE s.name=‘张三‘;

第二步:根据运动员的编号,找到参加的项目的编号

SELECT g.itemid
FROM grade g
WHERE g.sporterid=(
    SELECT s.sporterid
    FROM sporter s
    WHERE s.name=‘张三‘);

第三步:修改以上的查询,找到所有的运动员的编号

SELECT g.sporterid
FROM grade g
WHERE g.itemid IN(
    SELECT g.itemid
    FROM grade g
    WHERE g.sporterid=(
        SELECT s.sporterid
        FROM sporter s
        WHERE s.name=‘张三‘));

第四步:根据运动员的编号找到运动员的姓名

SELECT name
FROM sporter
WHERE sporterid IN(
    SELECT g.sporterid
    FROM grade g
    WHERE g.itemid IN(
        SELECT g.itemid
        FROM grade g
        WHERE g.sporterid=(
            SELECT s.sporterid
            FROM sporter s
            WHERE s.name=‘张三‘)))
    AND name<>‘张三‘;

4、  经查张三因为使用了违禁药品,其成绩都记0分,请在数据库中作出相应修改。

现在只是知道了张三的姓名,却不知道运动员编号,而成绩需要在grade表中通过运动员编号更新。

UPDATE grade SET mark=0 WHERE sporterid=(
    SELECT sporterid FROM sporter WHERE name=‘张三‘);

5、  经组委会协商,需要删除女子跳高比赛项目。

项目删除之后对应的成绩也应该消失,而在之前已经配置了级联删除了,所以直接删除父表即可。

DELETE FROM item WHERE itemname=‘女子跳高‘;
时间: 2024-07-29 02:19:47

Oracle笔记(十一) 建表、更新、查询综合练习的相关文章

Oracle笔记(四) 简单查询、限定查询、数据的排序

Oracle笔记(四) 简单查询.限定查询.数据的排序 一.简单查询 SQL(Structured Query Language) 结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理关系数据库系统.ANSI(美国国家标准学会)声称,SQL是关系数据库管理系统的标准语言. Oracle数据库之所以发展的很好,主要也是因为Oracle是全世界最早采用SQL语句的数据库产品. SQL功能强大,概括起来,它可以分成以下几组: DML(Data Manipulation La

Oracle笔记(八) 复杂查询及总结

Oracle笔记(八) 复杂查询及总结 一.复杂查询 1. 列出至少有一个员工的所有部门编号.名称,并统计出这些部门的平均工资.最低工资.最高工资. 1.确定所需要的数据表: emp表:可以查询出员工的数量: dept表:部门名称: emp表:统计信息: 2.确定已知的关联字段: emp.deptno=dept.deptno: 第一步:找出至少有一个员工的部门编号 SELECT deptno,COUNT(empno) FROM emp GROUP BY deptno HAVING COUNT(e

Unity3D 连接MySQL数据库笔记3-SQL建表

打开  Navicat MySQL管理工具 连接到数据库 选择 test 数据库 点击 查询 输入对应的 sql命令 create table tuser( uname varchar(20) not null primary key, upwd varchar(20) not null ); create table p_info( pkey varchar(15) not null primary key, pname varchar(20) not null, psex varchar(2

Oracle 数据库(oracle Database)Select 多表关联查询方式

Oracle数据库中Select语句语法及介绍 SELECT [ ALL | DISTINCT ] <字段表达式1[,<字段表达式2[,…] FROM <表名1>,<表名2>[,…] [WHERE <筛选择条件表达式>] [GROUP BY <分组表达式> [HAVING<分组条件表达式>]] [ORDER BY <字段>[ASC | DESC]] 语句说明: []方括号为可选项 [GROUP BY <分组表达式&g

mysql 建表和查询 大全 (待补全)

#新建学生表 drop table if exists student; create table student( sno varchar(20) not null primary key comment '学号', sname varchar(20) not null comment '学生姓名', ssex varchar(20) not null comment '学生性别', sbirthday Datetime comment '学生出生年月', class varchar(20)

oracle数据库的建表,删除字段,添加字段,修改字段,修改字段......

1. 使用oracle创建一张表: SQL> create table loginuser( 2 id number(10,2), 3 username varchar(20), 4 password varchar(20), 5 email varchar(30), 6 descriable varchar2(200), 7 regdate date); 创建表的语法: CREATE TABLE table_name( columns_name datatype,...... ); 显示创建表

oracle笔记1:-安装-体系结构-基本查询

一.Oracle数据库的安装(安装在虚拟机的xp系统里)     1.安装虚拟机     2.虚拟机内安装xp系统,以下步骤在虚拟机内进行     3.双击setup.exe,在出现的界面中设置口令,及确认口令(此口令即为system账号的密码),点击下一步     4.先决条件检查,将"用户已验证前面的复选框打勾,下一步     5.概要界面,点击安装     6.安装完成后,自动运行配置向导     7.口令管理界面,点击"口令管理"解锁SCOTT和HR两个账户    

MySQL - 建库、建表、查询

本章通过演示如何使用mysql客户程序创造和使用一个简单的数据库,提供一个MySQL的入门教程.mysql(有时称为“终端监视器”或只是“监视”)是一个交互式程序,允许你连接一个MySQL服务器,运行查询并察看结果.mysql可以用于批模式:你预先把查询放在一个文件中,然后告诉mysql执行文件的内容.使用mysql的两个方法都在这里涉及. 为了看清由mysql提供的一个选择项目表了,用--help选项调用它: shell> mysql --help 本章假定mysql已经被安装在你的机器上,并

SQL 建表与查询 HTML计算时间差

create database xue1 go --创建数据库 use xue1 go --引用数据库 create table xinxi ( code int, name varchar(20), xuehao decimal(10), brithday decimal(10), ) --创建信息表 insert into xinxi values(1,'张三',2016042701,2016-4-27) insert into xinxi values(2,'李四',2016042702,

涂抹Oracle笔记1-创建数据库及配置监听程序

一.安装ORACLE数据库软件OLTP:online transaction processing 指那些短事务,高并发,读写频繁的数据库系统.--DB_BLOCK_SIZE通常设置较小.OLAP:online analysis processing 指那些处理长事务,低并发,多读少写的数据库系统.---DB_BLOCK_SIZE通常设置较大,如32K. ASM:automatic storage management 自动存储管理系统,独立于操作系统的一种存储管理系统,直接通过操作系统看不到存