sql 练习题(1)

-- 1、查询"01"课程比"02"课程成绩高的学生的信息及课程分数
-- mark一下,"一个表当两个表用"
SELECT a.* ,b.s_score AS 01_score,c.s_score AS 02_score FROM
student a
    JOIN score b ON a.s_id=b.s_id AND b.c_id=‘01‘
    LEFT JOIN score c ON a.s_id=c.s_id AND c.c_id=‘02‘ OR c.c_id = NULL WHERE b.s_score>c.s_score

-- 也可以这样写
    SELECT a.*,b.s_score AS 01_score,c.s_score AS 02_score FROM student a,score b,score c
            WHERE a.s_id = b.s_id
            AND a.s_id = c.s_id
            AND b.c_id = ‘01‘
            AND c.c_id = ‘02‘
            AND b.s_score > c.s_score

-- 2、查询"01"课程比"02"课程成绩低的学生的信息及课程分数

SELECT a.* ,b.s_score AS 01_score,c.s_score AS 02_score FROM
    student a LEFT JOIN score b ON a.s_id=b.s_id AND b.c_id=‘01‘ OR b.c_id=NULL
     JOIN score c ON a.s_id=c.s_id AND c.c_id=‘02‘ WHERE b.s_score < c.s_score

-- 3、查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩
SELECT b.s_id,b.s_name,ROUND(AVG(a.s_score),2) AS avg_score FROM
    student b
    JOIN score a ON b.s_id = a.s_id
    GROUP BY b.s_id,b.s_name HAVING avg_score >=60;

-- 4、查询平均成绩小于60分的同学的学生编号和学生姓名和平均成绩
        -- (包括有成绩的和无成绩的)
SELECT a.s_id 学生编号,ROUND(AVG(a.s_score),2) 平均成绩, b.s_name 学生姓名  FROM score a
LEFT JOIN student b ON a.`s_id` = b.`s_id`
GROUP BY a.s_id ,b.s_name
HAVING AVG(a.s_score) < 60
UNION
SELECT a.s_id 学生编号,0 平均成绩, a.s_name 学生姓名  FROM student a
WHERE a.`s_id` NOT IN (SELECT DISTINCT score.s_id FROM score)

-- 5、查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩
SELECT s.s_id 编号, s.s_name 姓名, COUNT(*) 选课数量, SUM(c.s_score) 总成绩
FROM student s LEFT JOIN score c ON s.s_id = c.s_id
GROUP BY s.s_id, s.s_name

-- 6、查询"李"姓老师的数量
SELECT COUNT(*) FROM teacher WHERE t_name LIKE ‘李%‘;
SELECT COUNT(1) FROM teacher WHERE t_name LIKE ‘李%‘;
SELECT COUNT(t_id) FROM teacher WHERE t_name LIKE ‘李%‘;

-- 7、查询学过"张三"老师授课的同学的信息
-- 解法1
SELECT s1.* FROM student s1 LEFT JOIN score s2 ON s1.`s_id` = s2.`s_id`
WHERE s2.`c_id` IN
(SELECT c.`c_id` 课程号 FROM
teacher t LEFT JOIN course c
ON t.`t_id` = c.`t_id`
WHERE t.`t_name` = ‘张三‘)

-- 解法2
SELECT a.* FROM student    a
LEFT JOIN score b ON a.s_id = b.s_id
WHERE b.c_id IN
(SELECT c_id FROM course WHERE t_id = (SELECT t_id FROM teacher WHERE t_name = ‘张三‘))

-- 8、查询没学过"张三"老师授课的同学的信息
-- 把第7题中的 in 换为 NOT IN 就是第8题的结果了吗?当然不是。
-- 正确思路:首先查询出张三授课的全部课程编码集合A,然后查询出每个学生所选的全部课程编码集合B,查询出B中编码出现在A中的对应的每条记录的学生学号集合,
--     不在该集合中的学生即为结果
SELECT * FROM
    student s
    WHERE s.s_id NOT IN(
        SELECT a.s_id FROM student a JOIN score b ON a.s_id=b.s_id WHERE b.c_id IN(
        SELECT a.c_id FROM course a LEFT JOIN teacher b ON a.t_id = b.t_id WHERE t_name =‘张三‘));

-- 9、查询学过编号为"01"并且也学过编号为"02"的课程的同学的信息

-- 解法1 ***  mark一下这种解法
SELECT a.* FROM
    student a,score b,score c
    WHERE a.s_id = b.s_id  AND a.s_id = c.s_id AND b.c_id=‘01‘ AND c.c_id=‘02‘;

--  解法2 :查出选课01的学生编号(记为A),查询选课02的并且出现在A中的学生编号,相当于二者取交集(即为应求的学生编号的集合)。
-- 注:mysql没有支持交集的关键字,只好采用in实现取两个查询结果的交集
SELECT s.* FROM student s WHERE s.s_id IN (
SELECT t.s_id FROM score t WHERE t.c_id = ‘02‘ AND t.s_id IN  (SELECT t.s_id FROM score t WHERE t.c_id = ‘01‘))

-- 10、查询学过编号为"01"但是没有学过编号为"02"的课程的同学的信息
SELECT s.* FROM student s WHERE s.s_id IN (
SELECT t.s_id FROM score t WHERE t.c_id = ‘01‘ AND t.s_id NOT IN (SELECT t.s_id FROM score t WHERE t.c_id = ‘02‘))

原文地址:https://www.cnblogs.com/Aug-20/p/12032011.html

时间: 2024-08-07 21:58:27

sql 练习题(1)的相关文章

经典SQL练习题

今天在网上找了几道经典的SQL练习题做了一下,虽然都不难,但是对打基础是很有好处的,在明白的基础上可以进一步做分析,来研究一下各种解法的优劣,甚至进行简单的优化..现在将题目和答案分享一下.我使用的是MYSQL 5.0,但是绝大部分都是标准SQL.表结构:CREATE TABLE STUDENT(SNO VARCHAR(3) NOT NULL, SNAME VARCHAR(4) NOT NULL,SSEX VARCHAR(2) NOT NULL, SBIRTHDAY DATETIME,CLASS

(转)经典SQL练习题

今天在网上找了几道经典的SQL练习题做了一下,虽然都不难,但是对打基础是很有好处的,在明白的基础上可以进一步做分析,来研究一下各种解法的优劣,甚至进行简单的优化..现在将题目和答案分享一下.我使用的是MySQL 5.0,但是绝大部分都是标准SQL.表结构:CREATE TABLE STUDENT(SNO VARCHAR(3) NOT NULL, SNAME VARCHAR(4) NOT NULL,SSEX VARCHAR(2) NOT NULL, SBIRTHDAY DATETIME,CLASS

基本SQL练习题--选课经典例题

为管理岗位业务培训信息,建立3个表: S (S#,SN,SD,SA) S#,SN,SD,SA 分别代表学号.学员姓名.所属单位.学员年龄 C (C#,CN ) C#,CN 分别代表课程编号.课程名称 SC ( S#,C#,G ) S#,C#,G 分别代表学号.所选修的课程编号.学习成绩 1. 使用标准SQL嵌套语句查询选修课程名称为’税收基础’的学员学号和姓名 --实现代码: Select SN,SD FROM S Where [S#] IN( Select [S#] FROM C,SC Whe

50道SQL练习题及答案与详细分析!!!

以前在学校还没有很认真地意识到,现在到了企业才发现sql是那么的重要,看到网上有很多的sql 练习题,特地拿来练练手! 数据表介绍 --1.学生表 Student(SId,Sname,Sage,Ssex) --SId 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别 --2.课程表 Course(CId,Cname,TId) --CId 课程编号,Cname 课程名称,TId 教师编号 --3.教师表 Teacher(TId,Tname) --TId 教师编号,Tname

50道sql练习题和答案

最近两年的工作没有写过多少SQL,感觉水平下降十分严重,网上找了50道练习题学习和复习 原文地址:50道SQL练习题及答案与详细分析 1.0数据表介绍 --1.学生表 Student(SId,Sname,Sage,Ssex) --SId 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别 --2.课程表 Course(CId,Cname,TId) --CId 课程编号,Cname 课程名称,TId 教师编号 --3.教师表 Teacher(TId,Tname) --TId 教

sql练习题(2)

-- 11.查询没有学全所有课程的同学的信息 -- 解法一:所学课程数量 < 课程数量 SELECT s.* FROM student s LEFT JOIN score s1 ON s.`s_id` = s1.`s_id` GROUP BY s1.`s_id` HAVING COUNT(s1.`c_id`) < (SELECT COUNT(1) FROM course) -- 解法二 SELECT * FROM student WHERE s_id NOT IN( SELECT s_id F

接近50道经典SQL练习题,附建表SQL解题SQL

说明 本文章整理了47道常见sql联系题,包括建表语句,表结构,习题列表,解题答案都涵盖在本文章内.文末提供了所用SQL脚本下载链接.所有解题答案都是本人自己写的,广大读者如果在阅读使用中,有任何问题欢迎留言,对我写的有问题的,欢迎指正,谢谢. 数据库:oracle11g 表结构 可使用plsql-工具-导入表,导入如下sql脚本. 表结构与数据.sql 学生表 Student(SId,Sname,Sage,Ssex)SId 学生编号,Sname 学生姓名,Sage 出生年月,Ssex 学生性别

很不错的sql练习题(select)

创建表和输入数据 CREATE TABLE STUDENT (SNO VARCHAR(3) NOT NULL,    SNAME VARCHAR(4) NOT NULL,    SSEX VARCHAR(2) NOT NULL,    SBIRTHDAY DATETIME,    CLASS VARCHAR(5)) go CREATE TABLE COURSE (CNO VARCHAR(5) NOT NULL,    CNAME VARCHAR(10) NOT NULL,    TNO VARC

SQL 练习题

一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表(四)所示,数据如表1-2的表(一)~表(四)所示.用SQL语句创建四个表并完成相关题目. 表1-1数据库的表结构 表(一)Student (学生表) 属性名 数据类型 可否为空 含 义 Sno Char(3) 否 学号(主码) Sname Char(8) 否 学生姓名 Ssex Char(2) 否

另一套Oracle SQL练习题

题干: 1 create table student( 2 sno varchar2(10) primary key, 3 sname varchar2(20), 4 sage number(2), 5 ssex varchar2(5) 6 ); 7 create table teacher( 8 tno varchar2(10) primary key, 9 tname varchar2(20) 10 ); 11 create table course( 12 cno varchar2(10)