Student(S#,Sname,Sage,Ssex) ѧÉú±í
Course(C#,Cname,T#) ¿Î³Ì±í
SC(S#,C#,score) ³É¼¨±í
Teacher(T#,Tname) ½Ìʦ±í
ÎÊÌ⣺
1¡¢²éѯ¡°001¡±¿Î³Ì±È¡°002¡±¿Î³Ì³É¼¨¸ßµÄËùÓÐѧÉúµÄѧºÅ£»
select a.S# from (select s#,score from SC where C#='001') a,(select s#,score
from SC where C#='002') b
where a.score>b.score and a.s#=b.s#;
2¡¢²éѯƽ¾ù³É¼¨´óÓÚ60·ÖµÄͬѧµÄѧºÅºÍƽ¾ù³É¼¨£»
select S#,avg(score)
from sc
group by S# having avg(score) >60;
3¡¢²éѯËùÓÐͬѧµÄѧºÅ¡¢ÐÕÃû¡¢Ñ¡¿ÎÊý¡¢×ܳɼ¨£»
select Student.S#,Student.Sname,count(SC.C#),sum(score)
from Student left Outer join SC on Student.S#=SC.S#
group by Student.S#,Sname
4¡¢²éѯÐÕ¡°ÀµÄÀÏʦµÄ¸öÊý£»
select count(distinct(Tname))
from Teacher
where Tname like 'Àî%';
5¡¢²éѯûѧ¹ý¡°Ò¶Æ½¡±ÀÏʦ¿ÎµÄͬѧµÄѧºÅ¡¢ÐÕÃû£»
select Student.S#,Student.Sname
from Student
where S# not in (select distinct( SC.S#) from SC,Course,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='Ҷƽ');
6¡¢²éѯѧ¹ý¡°001¡±²¢ÇÒҲѧ¹ý±àºÅ¡°002¡±¿Î³ÌµÄͬѧµÄѧºÅ¡¢ÐÕÃû£»
select Student.S#,Student.Sname from Student,SC where Student.S#=SC.S# and SC.C#='001'and exists( Select * from SC as SC_2 where SC_2.S#=SC.S# and SC_2.C#='002');
7¡¢²éѯѧ¹ý¡°Ò¶Æ½¡±ÀÏʦËù½ÌµÄËùÓпεÄͬѧµÄѧºÅ¡¢ÐÕÃû£»
select S#,Sname
from Student
where S# in (select S# from SC ,Course ,Teacher where SC.C#=Course.C# and Teacher.T#=Course.T# and Teacher.Tname='Ҷƽ' group by S# having count(SC.C#)=(select count(C#) from Course,Teacher where Teacher.T#=Course.T# and Tname='Ҷƽ'));
8¡¢²éѯ¿Î³Ì±àºÅ¡°002¡±µÄ³É¼¨±È¿Î³Ì±àºÅ¡°001¡±¿Î³ÌµÍµÄËùÓÐͬѧµÄѧºÅ¡¢ÐÕÃû£»
Select S#,Sname from (select Student.S#,Student.Sname,score ,(select score from SC SC_2 where SC_2.S#=Student.S# and SC_2.C#='002') score2
from Student,SC where Student.S#=SC.S# and C#='001') S_2 where score2 60);
10¡¢²éѯûÓÐѧȫËùÓпεÄͬѧµÄѧºÅ¡¢ÐÕÃû£»
select Student.S#,Student.Sname
from Student,SC
where Student.S#=SC.S# group by Student.S#,Student.Sname having count(C#) <(select count(C#) from Course);
11¡¢²éѯÖÁÉÙÓÐÒ»ÃÅ¿ÎÓëѧºÅΪ¡°1001¡±µÄͬѧËùѧÏàͬµÄͬѧµÄѧºÅºÍÐÕÃû£»
select S#,Sname from Student,SC where Student.S#=SC.S# and C# in select C# from SC where S#='1001';
12¡¢²éѯÖÁÉÙѧ¹ýѧºÅΪ¡°001¡±Í¬Ñ§ËùÓÐÒ»ÃÅ¿ÎµÄÆäËûͬѧѧºÅºÍÐÕÃû£»
select distinct SC.S#,Sname
from Student,SC
where Student.S#=SC.S# and C# in (select C# from SC where S#='001');
13¡¢°Ñ¡°SC¡±±íÖС°Ò¶Æ½¡±ÀÏʦ½ÌµÄ¿ÎµÄ³É¼¨¶¼¸ü¸ÄΪ´Ë¿Î³ÌµÄƽ¾ù³É¼¨£»
update SC set score=(select avg(SC_2.score)
from SC SC_2
where SC_2.C#=SC.C# ) from Course,Teacher where Course.C#=SC.C# and Course.T#=Teacher.T# and Teacher.Tname='Ҷƽ');
14¡¢²éѯºÍ¡°1002¡±ºÅµÄͬѧѧϰµÄ¿Î³ÌÍêÈ«ÏàͬµÄÆäËûͬѧѧºÅºÍÐÕÃû£»
select S# from SC where C# in (select C# from SC where S#='1002')
group by S# having count(*)=(select count(*) from SC where S#='1002');
15¡¢É¾³ýѧϰ¡°Ò¶Æ½¡±ÀÏʦ¿ÎµÄSC±í¼Ç¼£»
Delect SC
from course ,Teacher
where Course.C#=SC.C# and Course.T#= Teacher.T# and Tname='Ҷƽ';
16¡¢ÏòSC±íÖвåÈëһЩ¼Ç¼£¬ÕâЩ¼Ç¼ҪÇó·ûºÏÒÔÏÂÌõ¼þ£ºÃ»ÓÐÉϹý±àºÅ¡°003¡±¿Î³ÌµÄͬѧѧºÅ¡¢2¡¢
ºÅ¿ÎµÄƽ¾ù³É¼¨£»
Insert SC select S#,'002',(Select avg(score)
from SC where C#='002') from Student where S# not in (Select S# from SC where C#='002');
17¡¢°´Æ½¾ù³É¼¨´Ó¸ßµ½µÍÏÔʾËùÓÐѧÉúµÄ¡°Êý¾Ý¿â¡±¡¢¡°ÆóÒµ¹ÜÀí¡±¡¢¡°Ó¢ÓÈýÃŵĿγ̳ɼ¨£¬°´ÈçÏÂÐÎʽÏÔʾ£º ѧÉúID,,Êý¾Ý¿â,ÆóÒµ¹ÜÀí,Ó¢Óï,ÓÐЧ¿Î³ÌÊý,ÓÐЧƽ¾ù·Ö
SELECT S# as ѧÉúID
,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='004') AS Êý¾Ý¿â
,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='001') AS ÆóÒµ¹ÜÀí
,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='006') AS Ó¢Óï
,COUNT(*) AS ÓÐЧ¿Î³ÌÊý, AVG(t.score) AS ƽ¾ù³É¼¨
FROM SC AS t
GROUP BY S#
ORDER BY avg(t.score)
18¡¢²éѯ¸÷¿Æ³É¼¨×î¸ßºÍ×îµÍµÄ·Ö£ºÒÔÈçÏÂÐÎʽÏÔʾ£º¿Î³ÌID£¬×î¸ß·Ö£¬×îµÍ·Ö
SELECT L.C# As ¿Î³ÌID,L.score AS ×î¸ß·Ö,R.score AS ×îµÍ·Ö
FROM SC L ,SC AS R
WHERE L.C# = R.C# and
L.score = (SELECT MAX(IL.score)
FROM SC AS IL,Student AS IM
WHERE L.C# = IL.C# and IM.S#=IL.S#
GROUP BY IL.C#)
AND
R.Score = (SELECT MIN(IR.score)
FROM SC AS IR
WHERE R.C# = IR.C#
GROUP BY IR.C#
);
19¡¢°´¸÷¿ÆÆ½¾ù³É¼¨´ÓµÍµ½¸ßºÍ¼°¸ñÂʵİٷÖÊý´Ó¸ßµ½µÍ˳Ðò
SELECT t.C# AS ¿Î³ÌºÅ,max(course.Cname)AS ¿Î³ÌÃû,isnull(AVG(score),0) AS ƽ¾ù³É¼¨
,100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) AS ¼°¸ñ°Ù·ÖÊý
FROM SC T,Course
where t.C#=course.C#
GROUP BY t.C#
ORDER BY 100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) DESC
20¡¢²éѯÈçÏÂ¿Î³ÌÆ½¾ù³É¼¨ºÍ¼°¸ñÂʵİٷÖÊý(ÓÃ"1ÐÐ"ÏÔʾ): ÆóÒµ¹ÜÀí£¨001£©£¬Âí¿Ë˼£¨002£©£¬OO&UML £¨003£©£¬Êý¾Ý¿â£¨004£©
SELECT SUM(CASE WHEN C# ='001' THEN score ELSE 0 END)/SUM(CASE C# WHEN '001' THEN 1 ELSE 0 END) AS ÆóÒµ¹ÜÀíÆ½¾ù·Ö
,100 * SUM(CASE WHEN C# = '001' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '001' THEN 1 ELSE 0 END) AS ÆóÒµ¹ÜÀí¼°¸ñ°Ù·ÖÊý
,SUM(CASE WHEN C# = '002' THEN score ELSE 0 END)/SUM(CASE C# WHEN '002' THEN 1 ELSE 0 END) AS Âí¿Ë˼ƽ¾ù·Ö
,100 * SUM(CASE WHEN C# = '002' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '002' THEN 1 ELSE 0 END) AS Âí¿Ë˼¼°¸ñ°Ù·ÖÊý
,SUM(CASE WHEN C# = '003' THEN score ELSE 0 END)/SUM(CASE C# WHEN '003' THEN 1 ELSE 0 END) AS UMLƽ¾ù·Ö
,100 * SUM(CASE WHEN C# = '003' AND score >= 60 THEN 1 E