찾다
数据库基本操作Jun 07, 2016 pm 03:59 PM
sagstudent기본 조작데이터 베이스데이터 시트

一、数据表 Student(S#,Sname,Sage,Ssex) 学生表 S#:学号;Sname:学生姓名;Sage:学生年龄;Ssex:学生性别 Course(C#,Cname,T#) 课程表 C#,课程编号;Cname:课程名字;T#:教师编号 SC(S#,C#,score) 成绩表 S#:学号;C#,课程编号;score:成绩 Teacher(

一、数据表 Student(S#,Sname,Sage,Ssex) 学生表 S#:学号;Sname:学生姓名;Sage:学生年龄;Ssex:学生性别
Course(C#,Cname,T#) 课程表 C#,课程编号;Cname:课程名字;T#:教师编号
SC(S#,C#,score) 成绩表 S#:学号;C#,课程编号;score:成绩
Teacher(T#,Tname) 教师表 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#=&#39;001&#39;) S_2 where score2 <score;
9、查询所有课程成绩小于60分的同学的学号、姓名;
      select S#,Sname
      from Student
      where S# not in (select Student.S# from Student,SC where S.S#=SC.S# and score>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#=&#39;1001&#39;;
12、查询至少学过学号为“001”同学所有一门课的其他同学学号和姓名;
       select distinct SC.S#,Sname
       from Student,SC
       where Student.S#=SC.S# and C# in (select C# from SC where S#=&#39;001&#39;);
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=&#39;叶平&#39;);
14、查询和“1002”号的同学学习的课程完全相同的其他同学学号和姓名;
       select S# from SC where C# in (select C# from SC where S#=&#39;1002&#39;)
       group by S# having count(*)=(select count(*) from SC where S#=&#39;1002&#39;);
15、删除学习“叶平”老师课的SC表记录;
       Delect SC
       from course ,Teacher 
       where Course.C#=SC.C# and Course.T#= Teacher.T# and Tname=&#39;叶平&#39;;
16、向SC表中插入一些记录,这些记录要求符合以下条件:没有上过编号“003”课程的同学学号、2、号课的平均成绩;
       Insert SC select S#,&#39;002&#39;,(Select avg(score)
       from SC where C#=&#39;002&#39;) from Student where S# not in (Select S# from SC where C#=&#39;002&#39;);
17、按平均成绩从高到低显示所有学生的“数据库”、“企业管理”、“英语”三门的课程成绩,按如下形式显示: 学生ID,,数据库,企业管理,英语, 有效课程数,有效平均分
        SELECT S# as 学生ID
           ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#=&#39;004&#39;) AS 数据库
           ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#=&#39;001&#39;) AS 企业管理
           ,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#=&#39;006&#39;) 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# =&#39;001&#39; THEN score ELSE 0 END)/SUM(CASE C# WHEN &#39;001&#39; THEN 1 ELSE 0 END) AS 企业管理平均分
            ,100 * SUM(CASE WHEN C# = &#39;001&#39; AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = &#39;001&#39; THEN 1 ELSE 0 END) AS 企业管理及格百分数
            ,SUM(CASE WHEN C# = &#39;002&#39; THEN score ELSE 0 END)/SUM(CASE C# WHEN &#39;002&#39; THEN 1 ELSE 0 END) AS 马克思平均分
            ,100 * SUM(CASE WHEN C# = &#39;002&#39; AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = &#39;002&#39; THEN 1 ELSE 0 END) AS 马克思及格百分数
            ,SUM(CASE WHEN C# = &#39;003&#39; THEN score ELSE 0 END)/SUM(CASE C# WHEN &#39;003&#39; THEN 1 ELSE 0 END) AS UML平均分
            ,100 * SUM(CASE WHEN C# = &#39;003&#39; AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = &#39;003&#39; THEN 1 ELSE 0 END) AS UML及格百分数
            ,SUM(CASE WHEN C# = &#39;004&#39; THEN score ELSE 0 END)/SUM(CASE C# WHEN &#39;004&#39; THEN 1 ELSE 0 END) AS 数据库平均分
            ,100 * SUM(CASE WHEN C# = &#39;004&#39; AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = &#39;004&#39; THEN 1 ELSE 0 END) AS 数据库及格百分数
      FROM SC
21、查询不同老师所教不同课程平均分从高到低显示
       SELECT max(Z.T#) AS 教师ID,MAX(Z.Tname) AS 教师姓名,C.C# AS 课程ID,MAX(C.Cname) AS 课程名称,AVG(Score) AS 平均成绩
       FROM SC AS T,Course AS C ,Teacher AS Z
       where T.C#=C.C# and C.T#=Z.T#
       GROUP BY C.C#
       ORDER BY AVG(Score) DESC
22、查询如下课程成绩第 3 名到第 6 名的学生成绩单:企业管理(001),马克思(002),UML (003),数据库(004)
[学生ID],[学生姓名],企业管理,马克思,UML,数据库,平均成绩
     SELECT  DISTINCT top 3
      SC.S# As 学生学号,
        Student.Sname AS 学生姓名 ,
      T1.score AS 企业管理,
      T2.score AS 马克思,
      T3.score AS UML,
      T4.score AS 数据库,
      ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) as 总分
      FROM Student,SC  LEFT JOIN SC AS T1
                      ON SC.S# = T1.S# AND T1.C# = &#39;001&#39;
            LEFT JOIN SC AS T2
                      ON SC.S# = T2.S# AND T2.C# = &#39;002&#39;
            LEFT JOIN SC AS T3
                      ON SC.S# = T3.S# AND T3.C# = &#39;003&#39;
            LEFT JOIN SC AS T4
                      ON SC.S# = T4.S# AND T4.C# = &#39;004&#39;
      WHERE student.S#=SC.S# and
      ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)
      NOT IN
      (SELECT
            DISTINCT
            TOP 15 WITH TIES
            ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)
      FROM sc
            LEFT JOIN sc AS T1
                      ON sc.S# = T1.S# AND T1.C# = &#39;k1&#39;
            LEFT JOIN sc AS T2
                      ON sc.S# = T2.S# AND T2.C# = &#39;k2&#39;
            LEFT JOIN sc AS T3
                      ON sc.S# = T3.S# AND T3.C# = &#39;k3&#39;
            LEFT JOIN sc AS T4
                      ON sc.S# = T4.S# AND T4.C# = &#39;k4&#39;
      ORDER BY ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) DESC);

23、统计列印各科成绩,各分数段人数:课程ID,课程名称,[100-85],[85-70],[70-60],[

       SELECT SC.C# as 课程ID, Cname as 课程名称
        ,SUM(CASE WHEN score BETWEEN 85 AND 100 THEN 1 ELSE 0 END) AS [100 - 85]
        ,SUM(CASE WHEN score BETWEEN 70 AND 85 THEN 1 ELSE 0 END) AS [85 - 70]
        ,SUM(CASE WHEN score BETWEEN 60 AND 70 THEN 1 ELSE 0 END) AS [70 - 60]
        ,SUM(CASE WHEN score < 60 THEN 1 ELSE 0 END) AS [60 -]
       FROM SC,Course
       where SC.C#=Course.C#
       GROUP BY SC.C#,Cname; 

24、查询学生平均成绩及其名次

       SELECT 1+(SELECT COUNT( distinct 平均成绩)
              FROM (SELECT S#,AVG(score) AS 平均成绩
                      FROM SC
                  GROUP BY S#
                  ) AS T1
            WHERE 平均成绩 > T2.平均成绩) as 名次,
         S# as 学生学号,平均成绩
        FROM (SELECT S#,AVG(score) 平均成绩
               FROM SC
            GROUP BY S#
              ) AS T2
        ORDER BY 平均成绩 desc;
25、查询各科成绩前三名的记录:(不考虑成绩并列情况)
      SELECT t1.S# as 学生ID,t1.C# as 课程ID,Score as 分数
      FROM SC t1
      WHERE score IN (SELECT TOP 3 score
              FROM SC
              WHERE t1.C#= C#
            ORDER BY score DESC
              )
      ORDER BY t1.C#;
26、查询每门课程被选修的学生数
       select c#,count(S#) from sc group by C#;
27、查询出只选修了一门课程的全部学生的学号和姓名
      select SC.S#,Student.Sname,count(C#) AS 选课数
      from SC ,Student
      where SC.S#=Student.S# group by SC.S# ,Student.Sname having count(C#)=1;
28、查询男生、女生人数
      Select count(Ssex) as 男生人数 from Student group by Ssex having Ssex=&#39;男&#39;;
      Select count(Ssex) as 女生人数 from Student group by Ssex having Ssex=&#39;女&#39;;
29、查询姓“张”的学生名单
      SELECT Sname FROM Student WHERE Sname like &#39;张%&#39;;
30、查询同名同性学生名单,并统计同名人数
      select Sname,count(*) from Student group by Sname having  count(*)>1;;
31、1981年出生的学生名单(注:Student表中Sage列的类型是datetime)
      select Sname,  CONVERT(char (11),DATEPART(year,Sage)) as age
      from student
      where  CONVERT(char(11),DATEPART(year,Sage))=&#39;1981&#39;;
32、查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时,按课程号降序排列
       Select C#,Avg(score) from SC group by C# order by Avg(score),C# DESC ;
33、查询平均成绩大于85的所有学生的学号、姓名和平均成绩
      select Sname,SC.S# ,avg(score)
      from Student,SC
      where Student.S#=SC.S# group by SC.S#,Sname having    avg(score)>85;
34、查询课程名称为“数据库”,且分数低于60的学生姓名和分数
      Select Sname,isnull(score,0)
      from Student,SC,Course
      where SC.S#=Student.S# and SC.C#=Course.C# and  Course.Cname=&#39;数据库&#39;and score <60;
35、查询所有学生的选课情况;
      SELECT SC.S#,SC.C#,Sname,Cname
      FROM SC,Student,Course
      where SC.S#=Student.S# and SC.C#=Course.C# ;
36、查询任何一门课程成绩在70分以上的姓名、课程名称和分数;
      SELECT  distinct student.S#,student.Sname,SC.C#,SC.score
      FROM student,Sc
      WHERE SC.score>=70 AND SC.S#=student.S#;
37、查询不及格的课程,并按课程号从大到小排列
      select c# from sc where scor e <60 order by C# ;
38、查询课程编号为003且课程成绩在80分以上的学生的学号和姓名;
      select SC.S#,Student.Sname from SC,Student where SC.S#=Student.S# and Score>80 and C#=&#39;003&#39;;
39、求选了课程的学生人数
      select count(*) from sc;
40、查询选修“叶平”老师所授课程的学生中,成绩最高的学生姓名及其成绩
      select Student.Sname,score
      from Student,SC,Course C,Teacher
      where Student.S#=SC.S# and SC.C#=C.C# and C.T#=Teacher.T# and Teacher.Tname=&#39;叶平&#39; and SC.score=(select max(score)from SC where C#=C.C# );
41、查询各个课程及相应的选修人数
      select count(*) from sc group by C#;
42、查询不同课程成绩相同的学生的学号、课程号、学生成绩
      select distinct  A.S#,B.score from SC A  ,SC B where A.Score=B.Score and A.C# <>B.C# ;
43、查询每门功成绩最好的前两名
      SELECT t1.S# as 学生ID,t1.C# as 课程ID,Score as 分数
        FROM SC t1
        WHERE score IN (SELECT TOP 2 score
                FROM SC
                WHERE t1.C#= C#
              ORDER BY score DESC
                )
        ORDER BY t1.C#;
44、统计每门课程的学生选修人数(超过10人的课程才统计)。要求输出课程号和选修人数,查询结果按人数降序排列,查询结果按人数降序排  

列,若人数相同,按课程号升序排列

       select  C# as 课程号,count(*) as 人数
       from  sc 
       group  by  C#
       order  by  count(*) desc,c# 
45、检索至少选修两门课程的学生学号
      select  S# 
      from  sc 
      group  by  s#
      having  count(*)  >  =  2
46、查询全部学生都选修的课程的课程号和课程名
      select  C#,Cname 
      from  Course 
      where  C#  in  (select  c#  from  sc group  by  c#) 
47、查询没学过“叶平”老师讲授的任一门课程的学生姓名  
      select Sname from Student where S# not in (select S# from Course,Teacher,SC where Course.T#=Teacher.T# and   
             SC.C#=course.C# and Tname=&#39;叶平&#39;); 

48、查询两门以上不及格课程的同学的学号及其平均成绩 

      select S#,avg(isnull(score,0)) from SC where S# in (select S# from SC where score <60 group by S# having 
             count(*)>2)group by S#; 

49、检索“004”课程分数小于60,按分数降序排列的同学学号

      select S# from SC where C#=&#39;004&#39;and score <60 order by score desc;
50、删除“002”同学的“001”课程的成绩
      delete from Sc where S#=&#39;002&#39;and C#=&#39;001&#39;;
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
深入理解MySQL索引优化器工作原理深入理解MySQL索引优化器工作原理Nov 09, 2022 pm 02:05 PM

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于索引优化器工作原理的相关内容,其中包括了MySQL Server的组成,MySQL优化器选择索引额原理以及SQL成本分析,最后通过 select 查询总结整个查询过程,下面一起来看一下,希望对大家有帮助。

sybase是什么数据库sybase是什么数据库Sep 22, 2021 am 11:39 AM

sybase是基于客户/服务器体系结构的数据库,是一个开放的、高性能的、可编程的数据库,可使用事件驱动的触发器、多线索化等来提高性能。

visual foxpro数据库文件是什么visual foxpro数据库文件是什么Jul 23, 2021 pm 04:53 PM

visual foxpro数据库文件是管理数据库对象的系统文件。在VFP中,用户数据是存放在“.DBF”表文件中;VFP的数据库文件(“.DBC”)中不存放用户数据,它只起将属于某一数据库的 数据库表与视图、连接、存储过程等关联起来的作用。

数据库系统的构成包括哪些数据库系统的构成包括哪些Jul 15, 2022 am 11:58 AM

数据库系统由4个部分构成:1、数据库,是指长期存储在计算机内的,有组织,可共享的数据的集合;2、硬件,是指构成计算机系统的各种物理设备,包括存储所需的外部设备;3、软件,包括操作系统、数据库管理系统及应用程序;4、人员,包括系统分析员和数据库设计人员、应用程序员(负责编写使用数据库的应用程序)、最终用户(利用接口或查询语言访问数据库)、数据库管理员(负责数据库的总体信息控制)。

microsoft sql server是什么软件microsoft sql server是什么软件Feb 28, 2023 pm 03:00 PM

microsoft sql server是Microsoft公司推出的关系型数据库管理系统,是一个全面的数据库平台,使用集成的商业智能(BI)工具提供了企业级的数据管理,具有使用方便可伸缩性好与相关软件集成程度高等优点。SQL Server数据库引擎为关系型数据和结构化数据提供了更安全可靠的存储功能,使用户可以构建和管理用于业务的高可用和高性能的数据应用程序。

数据库的什么是指数据的正确性和相容性数据库的什么是指数据的正确性和相容性Jul 04, 2022 pm 04:59 PM

数据库的“完整性”是指数据的正确性和相容性。完整性是指数据库中数据在逻辑上的一致性、正确性、有效性和相容性。完整性对于数据库系统的重要性:1、数据库完整性约束能够防止合法用户使用数据库时向数据库中添加不合语义的数据;2、合理的数据库完整性设计,能够同时兼顾数据库的完整性和系统的效能;3、完善的数据库完整性有助于尽早发现应用软件的错误。

access数据库的结构层次是什么access数据库的结构层次是什么Aug 26, 2022 pm 04:45 PM

结构层次是“数据库→数据表→记录→字段”;字段构成记录,记录构成数据表,数据表构成了数据库。数据库是一个完整的数据的记录的整体,一个数据库包含0到N个表,一个表包含0到N个字段,记录是表中的行。

mysql查询慢的因素除了索引,还有什么?mysql查询慢的因素除了索引,还有什么?Jul 19, 2022 pm 08:22 PM

mysql查询为什么会慢,关于这个问题,在实际开发经常会遇到,而面试中,也是个高频题。遇到这种问题,我们一般也会想到是因为索引。那除开索引之外,还有哪些因素会导致数据库查询变慢呢?

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.