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

2014-11-24 12:20:23 · 作者: · 浏览: 10
.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='张三');
第三步:修改以上的查询,找到所有的运动员的编号
www.2cto.com
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<>'张三';
www.2cto.com
4、 经查张三因为使用了违禁药品,其成绩都记0分,请在数据库中作出相应修改。
现在只是知道了张三的姓名,却不知道运动员编号,而成绩需要在grade表中通过运动员编号更新。
UPDATE grade SET mark=0 WHERE sporterid=(
SELECT sporterid FROM sporter WHERE name='张三');
5、 经组委会协商,需要删除女子跳高比赛项目。
项目删除之后对应的成绩也应该消失,而在之前已经配置了级联删除了,所以直接删除父表即可。
DELETE FROM item WHERE itemname='女子跳高';