Oracle的关于建表,约束,查询等的练习
从建立一个简单表,到实现一些复杂查询的例子,
DROP TABLE grade;
DROP TABLE item;
DROP TABLE sporter;
CREATE TABLE sporter(
sporterid NUMBER(4) PRIMARY KEY NOT NULL,
name VARCHAR(50) NOT NULL,
sex VARCHAR(2) NOT NULL,
department VARCHAR(30) NOT NULL,
CONSTRAINT sporter_sex_CK CHECK(sex IN('男','女'))
);
CREATE TABLE item(
itemid VARCHAR(4) PRIMARY KEY NOT NULL,
itemname VARCHAR(50) NOT NULL,
location VARCHAR(50) NOT NULL
);
CREATE TABLE grade(
sporterid NUMBER(4),
itemid VARCHAR(4),
mark NUMBER(2),
CONSTRAINT sport_grade_sporterid_fk FOREIGN KEY(sporterid) REFERENCES sporter(sporterid) ON DELETE CASCADE,
CONSTRAINT item_grade_sporterid_fk FOREIGN KEY(itemid) REFERENCES item(itemid) ON DELETE CASCADE,
CONSTRAINT grade_mark_CK CHECK(mark IN (6,4,2,0))
);
-- 测试数据
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,'孙俪','女','数学系');
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','女子三千米','三操场');
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);
要求:
1.求出目前总积分最高的系名,及其积分:
·所有的系名都在SPORTERID表之中
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
;
·不使用ROWNUM
·求出最大的分数值
SELECT MAX(SUM(g.mark)) max
FROM sporter s,grade g
WHERE s.sporterid=g.sporterid
GROUP BY s.department
·把上面的最大分数值作为子查询作为子查询
SELECT t.* FROM (
SELECT s.department de,SUM(g.mark) sum
FROM sporter s,grade g
WHERE s.sporterid=g.sporterid
GROUP BY s.department
ORDER BY sum DESC) t
WHERE t.sum=(
SELECT MAX(SUM(g.mark)) max
FROM sporter s,grade g
WHERE s.sporterid=g.sporterid
GROUP BY s.department)
;
2.找出在二操场进行比赛的各个项目名称,及其冠军的姓名
·求出最高成绩的 项目ID 和 分数
SELECT i.itemname,s.name,g.mark
FROM item i,grade g,sporter s
WHERE i.location='二操场'
AND i.itemid=g.itemid
AND s.sporterid=g.sporterid
;
·根据最高分得出
SELECT i.itemname,s.name,g.mark
FROM item i,grade g,sporter s
WHERE i.location='二操场'
AND i.itemid=g.itemid
AND s.sporterid=g.sporterid
AND g.mark IN(
SELECT MAX(mark) FROM (
SELECT i.itemname itemname,s.name name,g.mark mark
FROM item i,grade g,sporter s
WHERE i.location='二操场'
AND i.itemid=g.itemid
AND s.sporterid=g.sporterid
)GROUP BY itemname
)
;
3.找出参加了张三所参加过的项目的其他同学的姓名
SELECT DISTINCT s.name FROM sporter s,grade g
WHERE s.sporterid=g.sporterid
AND s.name<>'张三'
AND g.itemid IN (
SELECT g.itemid
FROM sporter s,grade g
WHERE s.sporterid=g.sporterid
AND s.name='张三'
)
;
4.经查张三因为使用了违禁药品,其成绩都记为0分,做出修改
UPDATE grade SET mark=0
WHERE sporterid=(
SELECT sporterid FROM sporter WHERE name='张三'
);
5.取消山粗女子跳高比赛项目
DELETE FROM item WHERE itemname='女子跳高';
Oracle的关于建表,约束,查询等的练习的更多相关文章
- Oracle 数据库(oracle Database)Select 多表关联查询方式
Oracle数据库中Select语句语法及介绍 SELECT [ ALL | DISTINCT ] <字段表达式1[,<字段表达式2[,…] FROM <表名1>,<表名 ...
- 64、django之模型层(model)--建表、查询、删除基础
要说一个项目最重要的部分是什么那铁定数据了,也就是数据库,这篇就开始带大家走进django关于模型层model的使用,model主要就是操纵数据库不使用sql语句的情况下完成数据库的增删改查.本篇仅带 ...
- django之模型层(model)--建表、查询、删除基础
要说一个项目最重要的部分是什么那铁定数据了,也就是数据库,这篇就开始带大家走进django关于模型层model的使用,model主要就是操纵数据库不使用sql语句的情况下完成数据库的增删改查.本篇仅带 ...
- 一次作业过程及其问题的记录:mysql建立数据库、建表、查询和插入等
前言 这次的作业需要我建立一个小的数据库. 这次作业我使用了mysql,进行了建库.建表.查询.插入等操作. 以下是对本次作业相关的mysql操作过程及过程中出现的问题的记录. 正文 作业中对数据库的 ...
- Oracle 存储过程动态建表
动态sql,顾名思义就是动态执行的sql,也就是说在没执行之前是动态的拼接的. 任务 传入参数:新建的表名hd+当前的年和月,例如hd_201105表结构是:字段1:id ,类型是number,可以自 ...
- sql 建表以及查询---复杂查询之成绩排名
废话不说,直接建表 1.表Player USE T4st -- 设置当前数据库为T4st,以便访问sysobjects IF EXISTS(SELECT * FROM sysobjects WHERE ...
- oracle数据库的建表,删除字段,添加字段,修改字段,修改字段......
1. 使用oracle创建一张表: SQL> create table loginuser( id ,), username ), password ), email ), descriable ...
- oracle之 获取建表ddl语句
第一种方法是使用工具,如:pl/sql developer,在[工具]--[导出用户对象]出现就可以得到建表脚本. 第二种方法是,sql语句. DBMS_METADATA.GET_DDL包可以得到数据 ...
- Django ORM --- 建表、查询、删除基础
1.什么是ORM ORM的全称是Object Relational Mapping,即对象关系映射.它的实现思想就是将关系数据库中表的数据映射成为对象,以对象的形式展现,这样开发人员就可以把对数据库的 ...
随机推荐
- CSS的base文件常用代码
article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body,but ...
- 疯狂Android第一章:Android环境配置以及基本概念
第一章 无关痒痛:Android Studio安装,配置,基本功能介绍! 重点内容:Android应用基本结构分析. 基础概念部分(只需知道作用,原理后见代码): Activity:安卓系统中负责与用 ...
- MapXtreme在asp.net中的使用之加载地图(转)
MapXtreme在asp.net中的使用之加载地图(转) Posted on 2010-05-04 19:44 Happy Coding 阅读(669) 评论(0) 编辑 收藏 1.地图保存在本地的 ...
- python 3.5 之 单双三引号
1. 单引号和双引号用法都是一样的,但是如果字符串里有相同的字符时要使用\进行转义 举例:1) print 'hello'2) print "hello"1和2,结果都是hello ...
- java+mysql中文乱码问题
乱码问题原因有多种,其中有一种是由于MySQL默认使用 ISO-8859-1 ( 即Latin1 ) 字符集,而JAVA内部使用Unicode编码,因此在JAVA中向MYSQL数据库插入数据时,或者读 ...
- ckeditor 使用手册
CKEditor使用手册 在使用CKEditor过程中遇到了一些问题,现把它整理成手册,以便随时翻阅. 在页面<head>中引入ckeditor核心文件ckeditor.js <sc ...
- oracle全文检索笔记
1.删除词法解析器 exec ctx_ddl.drop_preference('my_lexer'); 2.创建中文词法解析器 exec ctx_ddl.create_preference ('my_ ...
- Lotto--poj2245
Lotto Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6605 Accepted: 4185 Description ...
- To and Fro(字符串水题)
To and Fro 点我 Problem Description Mo and Larry have devised a way of encrypting messages. They first ...
- 微软云基础架构Hyper-scale Datacenter
每天醒来,可能很多人的习惯都是打开手机,看看微信,刷刷朋友圈,或者看看新闻,去咖啡店,打开电脑搜索一些关键字,观看视频,电视剧--可是你有没有想过你每一次键盘的敲击,每一次微信的语音的发送,数据会流向 ...