出处:http://blog.csdn.net/lk_blog/article/details/7585540

写sql是程序员基本功课,找工作面试一般必有sql题,实际工作中对sql的需求更是千变万化,所以掌握好sql对于一个程序员来说是件非常重要的事情.本文通过一个简单易懂的关系(学生/课程/成绩关系)尽量构造出各种各样的需求来提高我们写sql的功底,其中有些sql还是有一些难度的,大多数sql我都给出了思考思路,希望本人N天的劳动成果对您有所帮助.

限于本人水平有限,有些地方的sql写的并不完美,希望大家不吝赐教.最后提一点小小的要求,希望大家对本文积极进行评论,大家的评论是我改进和提高的动力,我希望在和大家的交流中得到提高.

表关系:


建表和初始化sql(本例子使用oralce数据库):

[sql]  view plain copy
  1. --创建表
  2. create table T_STUDENT(sno NUMBER not null,  sname VARCHAR2(30),  sdree VARCHAR2(50),  sage  NUMBER,  ssex  CHAR(2));
  3. alter table T_STUDENT add primary key (SNO);
  4. create table T_SCORE(sno   NUMBER,  cno   NUMBER,  grade NUMBER(4,1), tno NUMBER,  id NUMBER not null);
  5. alter table T_SCORE add primary key (ID);
  6. create table T_COURSE(cno NUMBER not null,  cname VARCHAR2(30));
  7. alter table T_COURSE add primary key (CNO);
  8. --初始化学生表
  9. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (1, '李坤', '天融信', 26, '男');
  10. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (2, '曹贵生', '中银', 26, '男');
  11. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (3, '柳波', '淘宝', 27, '男');
  12. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (4, '纪争光', 'IBM', 23, '男');
  13. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (5, '李学宇', '微软', 25, '女');
  14. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (6, '李雪琪', '文思', 25, '女');
  15. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (7, '陈绪', '百度', 26, '男');
  16. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (8, '韩正阳', '中海油', 24, '男');
  17. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (9, '陈伟东', '腾讯', 24, '男');
  18. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (10, '刘兵', '华为', 24, '男');
  19. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (11, '丁成云', '联想', 25, '女');
  20. insert into T_STUDENT (SNO, SNAME, SDREE, SAGE, SSEX) values (12, '王鹏', '中兴', 25, '男');
  21. commit;
  22. --初始化课程表
  23. insert into T_COURSE (CNO, CNAME) values (1, 'JAVA程序设计');
  24. insert into T_COURSE (CNO, CNAME) values (2, 'ORACLE开发');
  25. insert into T_COURSE (CNO, CNAME) values (3, 'C++程序设计');
  26. insert into T_COURSE (CNO, CNAME) values (4, 'C#程序设计');
  27. insert into T_COURSE (CNO, CNAME) values (5, 'Windows实战');
  28. insert into T_COURSE (CNO, CNAME) values (6, 'Center OS教程');
  29. insert into T_COURSE (CNO, CNAME) values (7, 'Jsp/Servlet开发');
  30. insert into T_COURSE (CNO, CNAME) values (8, 'J2EE从入门到精通');
  31. insert into T_COURSE (CNO, CNAME) values (9, 'EJB及设计模式');
  32. insert into T_COURSE (CNO, CNAME) values (10, 'Javascript/jQuery实战');
  33. insert into T_COURSE (CNO, CNAME) values (11, 'Flash设计');
  34. insert into T_COURSE (CNO, CNAME) values (12, 'HTML/CSS/JAVASCRIPT实战');
  35. insert into T_COURSE (CNO, CNAME) values (13, '精通ASP.NET');
  36. insert into T_COURSE (CNO, CNAME) values (14, 'JBoss入门');
  37. insert into T_COURSE (CNO, CNAME) values (15, 'Spring开发');
  38. commit;
  39. --初始化成绩表
  40. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (1, 2, 90.0, 2, 1);
  41. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (1, 3, 80.0, 3, 2);
  42. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (1, 4, 90.0, 4, 3);
  43. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 2, 70.0, 2, 4);
  44. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (2, 11, 66.0, 11, 5);
  45. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (2, 15, 77.0, 15, 6);
  46. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (2, 8, 87.0, 8, 7);
  47. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (2, 6, 96.0, 6, 8);
  48. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (3, 2, 89.0, 2, 9);
  49. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (3, 1, 91.0, 1, 10);
  50. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (4, 2, 83.0, 2, 11);
  51. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (5, 4, 73.0, 4, 12);
  52. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (5, 1, 60.0, 1, 13);
  53. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (5, 8, 82.0, 8, 14);
  54. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (6, 8, 90.5, 10, 15);
  55. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (8, 2, 58.0, 2, 16);
  56. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 3, 80.0, 3, 17);
  57. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (9, 11, 65.0, 11, 18);
  58. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (9, 12, 67.0, 12, 19);
  59. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (9, 15, 95.0, 15, 20);
  60. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (9, 13, 59.0, 13, 21);
  61. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (10, 4, 98.0, 4, 22);
  62. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (10, 6, 97.0, 6, 23);
  63. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (10, 7, 96.0, 7, 24);
  64. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 7, 95.0, 7, 25);
  65. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (12, 8, 69.0, 8, 26);
  66. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (12, 9, 85.0, 9, 27);
  67. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (10, 14, 100.0, 14, 28);
  68. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (6, 9, 100.0, 9, 29);
  69. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 1, 59.0, 1, 30);
  70. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 4, 90.0, 4, 31);
  71. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 5, 91.0, 5, 32);
  72. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 6, 58.0, 6, 33);
  73. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 8, 93.0, 8, 34);
  74. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 9, 57.0, 9, 35);
  75. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 10, 95.0, 10, 36);
  76. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 11, 96.0, 11, 37);
  77. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 12, 97.0, 12, 38);
  78. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 13, 98.0, 13, 39);
  79. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 14, 99.0, 14, 40);
  80. insert into T_SCORE (SNO, CNO, GRADE, TNO, ID) values (11, 15, 89.0, 15, 41);
  81. commit;

在思维举重前,先来一个热身运动吧:

[sql]  view plain copy
  1. --(一)查询选修课程名称为'JAVA程序设计'的学员学号和姓名
  2. --方法一:
  3. --1.查询'JAVA程序设计'这门课程的课程号
  4. --2.在成绩表中查询课程号为步骤1的课程号的成绩信息..
  5. --3.在学生表中查询学号为步骤2结果的学生信息
  6. select st.sno, st.sname
  7. from student st
  8. where st.sno in
  9. (select sno
  10. from score sc
  11. where sc.cno =
  12. (select co.cno from course co where co.cname = 'JAVA程序设计'));
  13. --方法二:
  14. --1.查询'JAVA程序设计'这门课程的课程号
  15. --2.在成绩表和学生表关联结果中查询课程号等于步骤1的课程号的成绩信息.
  16. --sql86
  17. select st.sno, st.sname
  18. from student st, score sc
  19. where st.sno = sc.sno
  20. and sc.cno =
  21. (select co.cno from course co where co.cname = 'JAVA程序设计');
  22. --sql92
  23. select st.sno, st.sname
  24. from student st
  25. join score sc
  26. on st.sno = sc.sno
  27. where sc.cno =
  28. (select co.cno from course co where co.cname = 'JAVA程序设计');
  29. --方法三:
  30. --1.在成绩表和课程表关联结果中查询选修了'JAVA程序设计'这门课的学生的学号
  31. --2.在学生表中查询步骤1中的学号的学生的详细信息.
  32. --sql86
  33. select st.sno, st.sname
  34. from student st
  35. where st.sno in (select sc.sno
  36. from score sc, course co
  37. where sc.cno = co.cno
  38. and co.cname = 'JAVA程序设计');
  39. --sql92
  40. select st.sno, st.sname
  41. from student st
  42. where st.sno in (select sc.sno
  43. from score sc
  44. join course co
  45. on sc.cno = co.cno
  46. where co.cname = 'JAVA程序设计');
  47. --方法四:
  48. --在成绩表和课程表和学生表三表关联的结果中过滤得到选修了 'JAVA程序设计'的学生基本信息
  49. --sql86
  50. select st.sno, st.sname
  51. from student st, score sc, course co
  52. where st.sno = sc.sno
  53. and co.cno = sc.cno
  54. and co.cname = 'JAVA程序设计';
  55. --sql92(1) 用where过滤
  56. select st.sno, st.sname
  57. from student st
  58. join score sc
  59. on st.sno = sc.sno
  60. join course co
  61. on co.cno = sc.cno
  62. where co.cname = 'JAVA程序设计';
  63. --sql92(2) 在关联条件中过滤
  64. select st.sno, st.sname
  65. from student st
  66. join score sc
  67. on st.sno = sc.sno
  68. join course co
  69. on co.cno = sc.cno
  70. and co.cname = 'JAVA程序设计';
  71. 注: 1.对于sql86 和sql92的区别见这篇文章: http://blog.csdn.net/lk_blog/article/details/7580300
  72. 2.如果您在看的过程中觉得不熟悉的地方很多,建议您先看此文: http://blog.csdn.net/lk_blog/article/details/7585501

进入正文:

[sql]  view plain copy
  1. --(一)查询不选修课程编号为'1'的学员姓名和所属单位
  2. --1.在成绩表中查询课程号为'1'的所有学生学号
  3. --2.在学生表中查询学号不在步骤1中的学生的基本信息.
  4. select st.sname, st.sdree
  5. from t_student st
  6. where st.sno not in (select sc.sno from t_score sc where sc.cno = '1');
  7. --(二)查询平均成绩大于85的所有学生的学号、姓名和平均成绩?
  8. select sc.sno, st.sname
  9. from t_score sc
  10. join t_student st
  11. on sc.sno = st.sno
  12. group by sc.sno, st.sname
  13. having avg(sc.grade) > 85;
  14. --(三)查询课程名称为"JAVA程序设计",且分数低于60的学生姓名和分数
  15. select *
  16. from t_score sc
  17. join t_course co
  18. on sc.cno = co.cno
  19. where sc.grade < 60
  20. and co.cname = 'JAVA程序设计'
  21. select *
  22. from t_score sc
  23. join t_course co
  24. on sc.cno = co.cno
  25. and sc.grade < 60
  26. and co.cname = 'JAVA程序设计'
  27. --(四)查询任何一门课程成绩全部都在70分以上的姓名、课程名称和分数?
  28. --1.查询出成绩小于70分的学生的学号.
  29. --2.将学生,成绩,课程三张表作关联.
  30. --3.在关联表中过滤出不在步骤1查询结果中的学生信息.
  31. select st.sname, co.cname, sc.grade
  32. from t_student st
  33. join t_score sc
  34. on st.sno = sc.sno
  35. join t_course co
  36. on sc.cno = co.cno
  37. where st.sno not in (select sc1.cno from t_score sc1 where sc1.grade < 70);
  38. --(五)查询出选了课的学生的人数.
  39. select count(distinct(sc.sno)) from t_score sc;
  40. --(六)查询每门课程被选课的学生数
  41. select sc.cno, count(distinct(sc.sno)) from t_score sc group by sc.cno;
  42. --(七)查询选了全部课程的学员姓名和所属单位
  43. --1.在课程表中查询出所有课程的数量
  44. --2.在成绩表中查询出学生选课数等于步骤1中总选课数的学生的学号,注意要用distinct,having中可以使用count,where中不能使用count.
  45. --3.在学生表中查出步骤2中学生的基本信息.
  46. select st.sname, st.sdree
  47. from t_student st
  48. where st.sno in
  49. (select sc.sno
  50. from t_score sc
  51. group by sc.sno
  52. having count(distinct sc.cno) = (select count(distinct sc1.cno)
  53. from t_course sc1));
  54. --(八) 查询没有学全所有课的同学的学号、姓名
  55. select st.sname, st.sdree
  56. from t_student st
  57. where st.sno in
  58. (select sc.sno
  59. from t_score sc
  60. group by sc.sno
  61. having count(distinct sc.cno) != (select count(*) from t_course));
  62. --(九)查询选修课程超过5门的学员学号和所属单位
  63. --1.在成绩表中查询出选课程超过5门的学生学号.
  64. --2.在学生表中查询步骤1中学号的学生的基本信息.
  65. select st.sname, st.sdree
  66. from t_student st
  67. where st.sno in (select sc.sno
  68. from t_score sc
  69. group by sc.sno
  70. having count(distinct sc.cno) > 5);
  71. --(十)查询出没有选课的学生基本信息
  72. --1.在成绩表中查询出所有选过课的学生的学号.
  73. --2.在学生表中查询出步骤1中学生的基本信息.
  74. select *
  75. from t_student st
  76. where st.sno not in (select sc.sno from t_score sc);
  77. --下面的两个sql等价,在成绩表中数据量很大时使用下面的sql
  78. select *
  79. from t_student st
  80. where st.sno not in (select distinct (sc.sno) from t_score sc);
  81. select *
  82. from t_student st
  83. where st.sno not in (select sc.sno from t_score sc group by sc.sno);
  84. --(十一) 列出有二门以上不及格课程的学生姓名及其平均成绩
  85. --方法一
  86. --1.在成绩表中查询出2门不及格学生的学号,结果记作t1
  87. --2.将学生表和t1和成绩表三表作关联得到关联表,在关联表中取学生基本信息和平均成绩.
  88. --sql92
  89. select st.sno, st.sname, avg(sc.grade)
  90. from t_student st
  91. join (select sc.sno
  92. from t_score sc
  93. where sc.grade < 60
  94. group by sc.sno
  95. having count(distinct sc.cno) > 2) t1
  96. on st.sno = t1.sno
  97. join t_score sc
  98. on sc.sno = t1.sno
  99. group by st.sno, st.sname;
  100. --sql86
  101. select st.sno, st.sname, avg(sc.grade)
  102. from t_student st,
  103. t_score sc,
  104. (select sc.sno
  105. from t_score sc
  106. where sc.grade < 60
  107. group by sc.sno
  108. having count(distinct sc.cno) > 2) t1
  109. where st.sno = t1.sno
  110. and sc.sno = t1.sno
  111. group by st.sno, st.sname;
  112. --方法二:
  113. --1.在成绩表中查询出2门不及格学生的学号
  114. --2.将学生表和成绩表通过学号作关联并根据步骤1中的结果作过滤,在关联结果中取出学生基本信息和平均成绩
  115. select st.sno, st.sname, avg(sc.grade)
  116. from t_student st
  117. join t_score sc
  118. on st.sno = sc.sno
  119. where st.sno in (select sc.sno
  120. from t_score sc
  121. where sc.grade < 60
  122. group by sc.sno
  123. having count(distinct sc.cno) > 2)
  124. group by st.sno, st.sname;
  125. --(十二) 查询平均成绩大于60分的同学的学号和平均成绩
  126. --学生表和课程表关联,在having子句中过滤平均成绩大于60分.
  127. select st.sno, avg(sc.grade)
  128. from t_student st, t_score sc
  129. where st.sno = sc.sno
  130. group by st.sno
  131. having avg(sc.grade) > 60;
  132. --1.学生表和课程表关联,将关联的结果记作t1
  133. --2.在t1中过滤平均成绩大于60的学生学号.
  134. select t1.sno, t1.avg_grade
  135. from (select st.sno, avg(sc.grade) avg_grade
  136. from t_student st, t_score sc
  137. where st.sno = sc.sno
  138. group by st.sno) t1
  139. where t1.avg_grade > 60;
  140. --(十三)查询出只选修了一门课程的全部学生的学号和姓名
  141. --方法一:
  142. --1.将学生表和成绩表作关联,在分组函数中使用having子句过滤出只选了一门课程的学生基本信息.
  143. select sc.sno, st.sname
  144. from t_score sc
  145. join t_student st
  146. on sc.sno = st.sno
  147. group by sc.sno, st.sname
  148. having count(distinct sc.cno) = 1;
  149. --方法二:
  150. --1.在成绩表中查找学号,分组函数的过滤条件判断只选择了一门课程的学生.
  151. --2.在学生表中查找学号在步骤1中的值的学生的基本信息
  152. select st.sno,st.sname
  153. from t_student st
  154. where st.sno in (select sc.sno
  155. from t_score sc
  156. group by sc.sno
  157. having count(distinct sc.cno) = 1);
  158. --(十四)查询至少有一门课与学号为"1"的同学所学相同的同学的学号和姓名
  159. select st.sno, st.sname
  160. from t_student st
  161. join t_score sc1
  162. on st.sno = sc1.sno
  163. where sc1.cno in (select sc.cno from t_score sc where sc.sno = '1')
  164. group by st.sno, st.sname;
  165. --(十五)列出既学过"1"号课程,又学过"2"号课程的所有学生姓名
  166. --1.将成绩表和课程表作关联,在关联条件中作过滤查询出既选过课程'1'又选过课程'2'的学生的学号,注意看 co.cno in ('1', '2')和having count(distinct sc.cno) = 2 的位置.
  167. --2.在学生表中根据步骤1的结果作过滤查询出学生的基本信息.
  168. --方法一:
  169. --sql86
  170. select st.sno, st.sname
  171. from t_student st,
  172. (select sc.sno
  173. from t_score sc, t_course co
  174. where sc.cno = co.cno
  175. and co.cno in ('1', '2')
  176. group by sc.sno
  177. having count(distinct sc.cno) = 2) t1
  178. where st.sno = t1.sno;
  179. --sql92
  180. select st.sno, st.sname
  181. from t_student st join
  182. (select sc.sno
  183. from t_score sc join t_course co
  184. on sc.cno = co.cno
  185. and co.cno in ('1', '2')
  186. group by sc.sno
  187. having count(distinct sc.cno) = 2) t1
  188. on st.sno = t1.sno;
  189. --方法二:
  190. --sql86
  191. select st.sno, st.sname
  192. from t_student st
  193. where st.sno in (select sc.sno
  194. from t_score sc, t_course co
  195. where sc.cno = co.cno
  196. and co.cno in ('1', '2')
  197. group by sc.sno
  198. having count(distinct sc.cno) = 2);
  199. --sql92
  200. select st.sno, st.sname
  201. from t_student st
  202. where st.sno in (select sc.sno
  203. from t_score sc
  204. join t_course co
  205. on sc.cno = co.cno
  206. and co.cno in ('1', '2')
  207. group by sc.sno
  208. having count(distinct sc.cno) = 2);
  209. --(十六)查询至少学过学号为"1"的同学所有门课的同学学号和姓名
  210. --1.查询出'1'号同学学习的全部课程.
  211. --2.查询出'1'号同学学习全部课程的数量.
  212. --3.将课程表和成绩表做关联,在关联表中查询出学生的学号,关联条件中加入过滤条件[课程号在步骤1查询结果范围内],过滤条件中加入数量等级步骤2中得到的数量.
  213. --4.在学生表中查询步骤3中的学号的学生的基本信息.
  214. select st.sno, st.sname
  215. from t_student st
  216. where st.sno in
  217. (select sc.sno
  218. from t_score sc
  219. join t_course co
  220. on sc.cno = co.cno
  221. and co.cno in (select sc.cno from t_score sc where sc.sno = '1')
  222. group by sc.sno
  223. having count(distinct sc.cno) = (select count(distinct sc.cno)
  224. from t_score sc
  225. where sc.sno = '1'))
  226. --(十七)查询和"6"号同学学习的课程完全相同的同学的学号和姓名
  227. --分析:要查询与6号同学完全相同的课程的学生信息,等价于学过6号同学的学过的所有课程并且选课数量与6同学选课数量相等.
  228. --方法一:
  229. --1.查询出'1'号同学学习的全部课程.
  230. --2.查询出'1'号同学学习全部课程的数量.
  231. --3.将课程表和成绩表做关联,在关联表中查询出学生的学号和选课数量,记作 t2,关联条件中加入过滤条件[课程号在步骤1查询结果范围内],过滤条件中加入数量等级步骤2中得到的数量.
  232. --4.在成绩表中查询出学号和每个学生选课数量.得到结果记作: t1
  233. --5.将步骤3中的t2和步骤4中的t1通过学生学号关联,添加过滤条件,t1中的选课数量等于t2中的选课数量.
  234. --6.在学生表中查询不步骤5的学生学号的基本信息.
  235. select st.sno, st.sname
  236. from t_student st
  237. where st.sno in
  238. (select t1.sno
  239. from (select sc_a.sno, count(distinct sc_a.cno) num_outer
  240. from t_score sc_a
  241. group by sc_a.sno) t1
  242. join (select sc.sno, count(distinct sc.cno) num_inner
  243. from t_score sc
  244. join t_course co
  245. on sc.cno = co.cno
  246. and co.cno in
  247. (select sc.cno from t_score sc where sc.sno = '6')
  248. group by sc.sno
  249. having count(distinct sc.cno) = (select count(distinct sc.cno)
  250. from t_score sc
  251. where sc.sno = '6')) t2
  252. on t1.sno = t2.sno
  253. where t1.num_outer = t2.num_inner);
  254. --(十八)列出"1"号课成绩比"2"号课成绩高的所有学生的学号及其"1"号课和"2"号课的成绩
  255. --1.将学生表和课程表作两次关联,一次关联用于取该学生课程'1'的成绩,另一次关联用于取该学生课程'2'的成绩.
  256. --sql86
  257. select st.sno, st.sname, sc_a.grade, sc_b.grade
  258. from t_student st, t_score sc_a, t_score sc_b
  259. where sc_a.cno = '1'
  260. and sc_b.cno = '2'
  261. and st.sno = sc_a.sno
  262. and st.sno = sc_b.sno
  263. and sc_a.grade > sc_b.grade
  264. --sql92
  265. select st.sno, st.sname, sc_a.grade, sc_b.grade
  266. from t_student st
  267. join t_score sc_a
  268. on st.sno = sc_a.sno
  269. join t_score sc_b
  270. on st.sno = sc_b.sno
  271. where sc_a.cno = '1'
  272. and sc_b.cno = '2'
  273. and sc_a.grade > sc_b.grade
  274. --(十九)查询所有同学的学号、姓名、选课数、总成绩
  275. select st.sno, st.sname, count(sc.cno), sum(sc.grade)
  276. from t_student st, t_score sc
  277. where st.sno = sc.sno
  278. group by st.sno, st.sname;
  279. --(二十)查询课程成绩小于60分的同学的学号,姓名,课程名,成绩
  280. --下面两条sql虽然结果相同,但意义不同,注意理解一下哦.
  281. --1.将学生表,课程表,成绩表作关联
  282. --2.对关联后的结果作过滤,过滤出成绩小于60的学生基本信息.
  283. select st.sno, st.sname, co.cname, sc.grade
  284. from t_score sc
  285. join t_student st
  286. on sc.sno = st.sno
  287. join t_course co
  288. on sc.cno = co.cno
  289. where sc.grade < 60
  290. --1.将学生表,课程表,成绩表作关联,在关联条件中过滤成绩小于60.
  291. select st.sno, st.sname, co.cname, sc.grade
  292. from t_score sc
  293. join t_student st
  294. on sc.sno = st.sno
  295. join t_course co
  296. on sc.cno = co.cno
  297. and sc.grade <60
  298. --(二十一)按平均成绩从到低显示所有学生的"JAVA程序设计"、"J2EE从入门到精通"、"EJB及设计模式"三门的课程成绩,
  299. --并按如下形式显示: 学生ID,姓名,JAVA程序设计,J2EE从入门到精通,EJB及设计模式,有效课程数,有效课程平均分
  300. --1.将成绩表和课程表关联得到结果记作: t1, 关联时的条件选择只统计以上三门课程.
  301. --2.按题目中的要求组织统计结果.
  302. select st.sno,
  303. st.sname,
  304. sum(decode(t1.cname, 'JAVA程序设计', t1.grade)) JAVA程序设计,
  305. sum(decode(t1.cname, 'J2EE从入门到精通', t1.grade)) J2EE从入门到精通,
  306. sum(decode(t1.cname, 'EJB及设计模式', t1.grade)) EJB及设计模式,
  307. count(distinct t1.grade) 有效课程数,
  308. avg(t1.grade) 有效课程平均分
  309. from t_student st
  310. join (select *
  311. from t_score sc
  312. join t_course co
  313. on sc.cno = co.cno
  314. and co.cname in
  315. ('JAVA程序设计', 'J2EE从入门到精通', 'EJB及设计模式')) t1
  316. on st.sno = t1.sno
  317. group by st.sno, st.sname
  318. --将decode可以换成case when 第一种形式
  319. select st.sno,
  320. st.sname,
  321. sum(case t1.cname
  322. when 'JAVA程序设计' then
  323. t1.grade
  324. end) JAVA程序设计,
  325. sum(case t1.cname
  326. when 'J2EE从入门到精通' then
  327. t1.grade
  328. end) J2EE从入门到精通,
  329. sum(case t1.cname
  330. when 'EJB及设计模式' then
  331. t1.grade
  332. end) EJB及设计模式,
  333. count(distinct t1.grade) 有效课程数,
  334. avg(t1.grade) 有效课程平均分
  335. from t_student st
  336. join (select *
  337. from t_score sc
  338. join t_course co
  339. on sc.cno = co.cno
  340. and co.cname in
  341. ('JAVA程序设计', 'J2EE从入门到精通', 'EJB及设计模式')) t1
  342. on st.sno = t1.sno
  343. group by st.sno, st.sname
  344. --将decode可以换成case when 第二种形式
  345. select st.sno,
  346. st.sname,
  347. sum(case
  348. when t1.cname = 'JAVA程序设计' then
  349. t1.grade
  350. end) JAVA程序设计,
  351. sum(case
  352. when t1.cname = 'J2EE从入门到精通' then
  353. t1.grade
  354. end) J2EE从入门到精通,
  355. sum(case
  356. when t1.cname = 'EJB及设计模式' then
  357. t1.grade
  358. end) EJB及设计模式,
  359. count(distinct t1.grade) 有效课程数,
  360. avg(t1.grade) 有效课程平均分
  361. from t_student st
  362. join (select *
  363. from t_score sc
  364. join t_course co
  365. on sc.cno = co.cno
  366. and co.cname in
  367. ('JAVA程序设计', 'J2EE从入门到精通', 'EJB及设计模式')) t1
  368. on st.sno = t1.sno
  369. group by st.sno, st.sname
  370. --(二十二)查询各科成绩最高和最低的分:以如下形式显示:课程ID,课程名,最高分,最低分
  371. select sc.cno, co.cname, max(grade), min(grade)
  372. from t_score sc
  373. join t_course co
  374. on sc.cno = co.cno
  375. group by sc.cno, co.cname
  376. --(二十三)按各科平均成绩从低到高和及格率的百分数从高到低顺序
  377. --1.在成绩表中查出课程号,平均成绩,课程人数,记作 : t1
  378. --2.在成绩表中查出课程号,及格的课程人数,记作 : t2
  379. --3.将步骤1中的成绩和步骤2中的课程2关联,查出所要的结果并排序.
  380. select t1.cno, t1.avg_num 平均成绩, (count_num1 / count_num) * 100 及格率
  381. from (select sc.cno, avg(grade) avg_num, count(distinct sc.sno) count_num
  382. from t_score sc
  383. group by sc.cno) t1
  384. join (select sc1.cno, count(distinct sc1.sno) count_num1
  385. from t_score sc1
  386. where sc1.grade > 60
  387. group by sc1.cno) t2
  388. on t1.cno = t2.cno
  389. order by t1.avg_num asc, 及格率 desc
  390. --(二十四)统计各科成绩,各分数段人数:课程ID,课程名称,[100-90]优,[90-80]良,[80-70]中,[70-60]一般,[<60]不及格
  391. --1.在成绩表中根据成绩值分段
  392. --2.将步骤1中的结果与课程表关联.
  393. select sc.cno,co.cname,
  394. sum(case
  395. when sc.grade > 90 then
  396. 1
  397. end) 优,
  398. sum(case
  399. when sc.grade > 80 and sc.grade < 90 then
  400. 1
  401. end) 良,
  402. sum(case
  403. when sc.grade > 70 and sc.grade < 80 then
  404. 1
  405. end) 中,
  406. sum(case
  407. when sc.grade > 60 and sc.grade < 70 then
  408. 1
  409. end) 一般,
  410. sum(case
  411. when sc.grade < 60 then
  412. 1
  413. end) 不及格
  414. from t_score sc join t_course co on sc.cno = co.cno
  415. group by sc.cno,co.cname
  416. --(二十五)查询学生平均成绩及其名次
  417. select st.sno, st.sname, avg(sc.grade) avg_num
  418. from t_score sc
  419. join t_student st
  420. on sc.sno = st.sno
  421. group by st.sno, st.sname
  422. order by avg_num desc
  423. --(二十六)查询课程号分别为1,2,3的课程,成绩前三名的学生基本信息:(不考虑成绩并列情况)
  424. --方法一:
  425. --1.分别查出1,2,3各自的前3名的学生的学号,并用union all将结果集关联.
  426. --2.在学生表中查询步骤1中查到的id的学生的基本信息.
  427. select *
  428. from t_student
  429. where sno in (select t1.sno
  430. from (select sc1.*
  431. from t_score sc1
  432. where sc1.cno = 1
  433. order by sc1.grade desc) t1
  434. where rownum < 4
  435. union all
  436. select t1.sno
  437. from (select sc1.*
  438. from t_score sc1
  439. where sc1.cno = 2
  440. order by sc1.grade desc) t1
  441. where rownum < 4
  442. union all
  443. select t1.sno
  444. from (select sc1.*
  445. from t_score sc1
  446. where sc1.cno = 3
  447. order by sc1.grade desc) t1
  448. where rownum < 4)
  449. --方法二:
  450. --rank() over(Partition .. order by ...) 是按照某个字段的值进行分组并编号
  451. select t1.cno, t1.sno, t1.grade, r
  452. from (select sc.sno,
  453. sc.cno,
  454. sc.grade,
  455. rank() over(partition by sc.cno order by grade desc) r
  456. from t_score sc) t1
  457. where r < 4
  458. and t1.cno in (1, 2, 3)
  459. order by t1.cno, t1.sno, r;
  460. --(二十七)查询各科成绩前三名的记录(不考虑成绩并列情况)
  461. --rank() over(Partition .. order by ...) 是按照某个字段的值进行分组并编号
  462. select t1.cno, t1.sno, t1.grade, r
  463. from (select sc.sno,
  464. sc.cno,
  465. sc.grade,
  466. rank() over(partition by sc.cno order by grade desc) r
  467. from t_score sc) t1
  468. where r < 4
  469. order by t1.cno, t1.sno, r;

高级程序员必修课--sql思维举重训练相关推荐

  1. 高级程序员必修课--sql思维举重训练 .

    写sql是程序员基本功课,找工作面试一般必有sql题,实际工作中对sql的需求更是千变万化,所以掌握好sql对于一个程序 员来说是件非常重要的事情.本文通过一个简单易懂的关系(学生/课程/成绩关系)尽 ...

  2. 程序员必修课--sql思维举重训练

    写sql是程序员基本功课,找工作面试一般必有sql题,实际工作中对sql的需求更是千变万化,所以掌握好sql对于一个程序员来说是件非常重要的事情.本文通过一个简单易懂的关系(学生/课程/成绩关系)尽量 ...

  3. sql -高级程序员必修课

    --创建表 create table T_STUDENT(sno NUMBER not null,  sname VARCHAR2(30),  sdree VARCHAR2(50),  sage  N ...

  4. 程序员必修课-sql语句

    sql是硬伤,以下这篇文章于我真是饕餮大餐,享受之余转来分享~~ 写sql是程序员基本功课,找工作面试一般必有sql题,实际工作中对sql的需求更是千变万化,所以掌握好sql对于一个程序员来说是件非常 ...

  5. 专门为程序员打造的思维“必修课”

    这是第一篇正式文章,来介绍一本最近刚刚出版的书吧! 对!就是它--<程序员的底层思维>. 介绍这本书的原因有三. 它适合几乎所有IT从业者阅读 内容零门槛,且十分具有启发性. 书中一共介绍 ...

  6. SqlServer注意事项总结,高级程序员必背。

    本篇文章主要介绍SqlServer使用时的注意事项. 想成为一个高级程序员,数据库的使用是必须要会的.而数据库的使用纯熟程度,也侧面反映了一个开发的水平. 下面介绍SqlServer在使用和设计的过程 ...

  7. java 面试,java 后端面试,数据库方面对初级和高级程序员的要求

    本内容摘自 java web轻量级开发面试教程 对于合格的程序员,需要有基本的数据库操作技能,具体体现在以下三个方面. l  第一,针对一类数据库(比如MySQL.Oracle.SQL Server等 ...

  8. 高级程序员必会的程序设计原则 —— 墨菲定律及防呆设计

    前言 如果你或你带领的团队经常会写出一些BUG,日常不是在解决BUG就是在解决BUG的路上,那么你的项目一定是应验了墨菲定律,并且在开发时并没有足够考虑防呆设计.团队越是疲于奔命,错的越是多. 简记 ...

  9. 初级,中级,高级程序员需要具备的能力

    1:团队精神和协作能力 把它作为基本素质,并不是不重要,恰恰相反,这是程序员应该具备的最基本的,也是最重要的安身立命之本.把高水平程序员说成独行侠的都是在呓语,任何个人的力量都是有限的,即便如linu ...

最新文章

  1. jqgrid如何渲染表格数据_jqgrid,jquery_jqGrid pivot 增加分项小计,jqgrid,jquery,jquery插件,javascript,表格 - phpStudy...
  2. putty 串口登录开发板
  3. 动效设计的物理法则:动画的一切皆在于时间点和空间幅度(转)
  4. Django的路由系统
  5. [NOIP2013] 花匠
  6. oracle循环不是a就取b,oracle数据库试题的.doc
  7. 相等变为1 编号_JavaScript 中的 4 个相等比较算法的介绍
  8. Leetcode每日一题:28.implement-strstr(实现strStr())
  9. pandas小记:pandas数据输入输出
  10. Java XLSTransformer生成excel文件
  11. SQL连接两张或多张表
  12. Java — set 和 list 集合练习题
  13. office、Excel控件生成条码
  14. linux复制文件到另一台服务器
  15. 幸运大转盘抽奖(前端uniapp)
  16. taptap需要相机权限_TapTap双击背部App-实现安卓11双击手机背面截屏拍照等新功能-软极客...
  17. TEXMACS在ubuntu下的使用
  18. rap技术原理_人们对Rap(说唱)理解的误区,你知道多少?
  19. cebemax hal库 stm32 OLED移植 解析
  20. ClickHouse函数介绍

热门文章

  1. 是什么阻碍了自己写博客
  2. 【Linux】进程概念(下篇) —— 程序地址空间详解
  3. 六、桥接模式——将多重继承增加一个旁路
  4. 【Unity】带有字符淡入效果的TextMeshPro打字机效果组件
  5. native app webapp
  6. 神经网络和深度学习(4)--符号约定
  7. 视频:三亚行-乘风破浪会有时
  8. docker 启动报Cannot set property TasksAccounting, or unknown property.
  9. cortex a7 a53_奥迪A7 升级原厂空气悬挂、FOGIAGO碳纤维进气套件、自动泊车辅助-改装作品...
  10. EDM支持国内外邮件群发系统源码