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 score260); 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