SQL面试练习(MySql)

创建测试数据库:

/*如果已经存在此数据库,先删除*/
drop database if exists sqltest  ;
/*创建并设置编码为UTF-8*/
create database sqltest default character set utf8 ;

 

一、单表查询

id sno name cno course score
2 20170101001 张三 1001 语文 86
3 20170101001 张三 1002 数学 56
4 20170101001 张三 1003 英语 48
5 20170101001 张三 1004 化学  90
6 20170101001 张三 1005 物理 57
7 20170101002 李四 1001 语文 90
8 20170101002 李四 1002 数学 68
9 20170101002 李四 1003 英语 87
10 20170101002 李四 1004 化学  68
11 20170101002 李四 1005 物理 45
12 20170101003 王五 1001 语文 86
13 20170101003 王五 1002 数学 60
14 20170101003 王五 1003 英语 48
15 20170101003 王五 1004 化学  90
16 20170101003 王五 1005 物理 70
17 20170101004 赵六 1001 语文 82
18 20170101004 赵六 1002 数学 80
19 20170101004 赵六 1003 英语 30
20 20170101004 赵六 1004 化学  70
21 20170101004 赵六 1005 物理 88

 

/*切换至测试数据库*/
use sqltest;

/*如果表存在,则删除*/
drop table if exists tb_score  ;

/*创建学生表ST*/
CREATE TABLE `tb_score` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `Sno` varchar(50) not null ,
  `name` varchar(50) DEFAULT NULL,
  `Cno` varchar(50) not null ,
  `course` varchar(50) DEFAULT NULL,
  `score` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

/*插入数据*/
insert into tb_score (sno,name,cno,course,score) value('20170101001','张三','1001','语文','86') ;
insert into tb_score (sno,name,cno,course,score) value('20170101001','张三','1002','数学','56') ;
insert into tb_score (sno,name,cno,course,score) value('20170101001','张三','1003','英语','48') ;
insert into tb_score (sno,name,cno,course,score) value('20170101001','张三','1004','化学','90') ;
insert into tb_score (sno,name,cno,course,score) value('20170101001','张三','1005','物理','57') ;

insert into tb_score (sno,name,cno,course,score) value('20170101002','李四','1001','语文','90') ;
insert into tb_score (sno,name,cno,course,score) value('20170101002','李四','1002','数学','68') ;
insert into tb_score (sno,name,cno,course,score) value('20170101002','李四','1003','英语','87') ;
insert into tb_score (sno,name,cno,course,score) value('20170101002','李四','1004','化学','68') ;
insert into tb_score (sno,name,cno,course,score) value('20170101002','李四','1005','物理','45') ;

insert into tb_score (sno,name,cno,course,score) value('20170101003','王五','1001','语文','86') ;
insert into tb_score (sno,name,cno,course,score) value('20170101003','王五','1002','数学','60') ;
insert into tb_score (sno,name,cno,course,score) value('20170101003','王五','1003','英语','48') ;
insert into tb_score (sno,name,cno,course,score) value('20170101003','王五','1004','化学','90') ;
insert into tb_score (sno,name,cno,course,score) value('20170101003','王五','1005','物理','70') ;

insert into tb_score (sno,name,cno,course,score) value('20170101004','赵六','1001','语文','82') ;
insert into tb_score (sno,name,cno,course,score) value('20170101004','赵六','1002','数学','80') ;
insert into tb_score (sno,name,cno,course,score) value('20170101004','赵六','1003','英语','30') ;
insert into tb_score (sno,name,cno,course,score) value('20170101004','赵六','1004','化学','70') ;
insert into tb_score (sno,name,cno,course,score) value('20170101004','赵六','1005','物理','88') ;

 

1.1查询不及格科目数大于等于2的学生学号、姓名和不及格科目数量:

/*不加having条件筛选*/
select sno as '学号' , name as '姓名' , count(score) as '不及格科目数' from tb_score where score < 60 group by sno ;

select sno as '学号' , name as '姓名' , count(score) as '不及格科目数' from tb_score where score < 60 group by sno having count(score) > 2 ;

 

1.2查询不及格科目数大于等于2的学生学号、姓名:

select sno as '学号' , name as '姓名' from tb_score where score < 60 group by sno having count(score) > 2 ;

 

1.3、查询不及格科目数大于等于2的学生学号、学生姓名、科目号、科目名称和分数,并按学号降序、科目号升序排序:

 中间步骤探索

select * from tb_score where score < 60 group by sno having count(score) >= 2 order by sno desc , cno asc ;

 最终结果

select * from tb_score where score < 60 and sno in (
    select sno from tb_score where score < 60 group by sno having count(score) >= 2 
)
order by sno desc , cno asc ;

 

 

 

二、多表查询

 

/*选择数据库*/
use sqltest ;

/*删除已有的学生表*/
drop table if exists tb_student ;

/*创建学生表*/
CREATE TABLE `tb_student` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `stuId` varchar(45) DEFAULT NULL,
  `name` varchar(45) DEFAULT NULL,
  `clsId` varchar(45) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

/*插入学生的数据*/
insert into tb_student (stuId,name,clsId) value ('1001','张三','201') ;
insert into tb_student (stuId,name,clsId) value ('1002','李四','201') ;
insert into tb_student (stuId,name,clsId) value ('1003','王五','201') ;
insert into tb_student (stuId,name,clsId) value ('1004','赵六','202') ;
insert into tb_student (stuId,name,clsId) value ('1005','巩发财','202') ;
insert into tb_student (stuId,name,clsId) value ('1006','柏拉图','202') ;
insert into tb_student (stuId,name,clsId) value ('1007','钱老虎','203') ;
insert into tb_student (stuId,name,clsId) value ('1008','杨伟','203') ;
insert into tb_student (stuId,name,clsId) value ('1009','陈海','203') ;
/*删除已有的班级表*/
drop table if exists tb_class ;

/*创建班级表*/
CREATE TABLE `tb_class` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `clsId` varchar(45) DEFAULT NULL,
  `name` varchar(45) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

/*插入班级的数据*/
insert into tb_class (clsId,name) value ('201','高二(1)班') ;
insert into tb_class (clsId,name) value ('202','高二(2)班') ;
insert into tb_class (clsId,name) value ('203','高二(3)班') ;
/*删除已有的课程表*/
drop table if exists tb_course ;

/*创建课程表*/
CREATE TABLE `tb_course` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `couId` varchar(45) DEFAULT NULL,
  `name` varchar(45) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

/*插入课程数据*/
insert into tb_course (couId,name) value ('A01','语文') ;
insert into tb_course (couId,name) value ('A02','数学') ;
insert into tb_course (couId,name) value ('A03','英语') ;

 

/*删除已有的分数表*/
drop table if exists tb_score ;

/*创建分数表*/
CREATE TABLE `tb_score` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `stuId` varchar(45) DEFAULT NULL,
  `couId` varchar(45) DEFAULT NULL,
  `score` float DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

/*插入分数数据*/
insert into tb_score (stuId,couId,score) value ('1001','A01',81) ;
insert into tb_score (stuId,couId,score) value ('1001','A02',73) ;
insert into tb_score (stuId,couId,score) value ('1001','A03',79) ;

insert into tb_score (stuId,couId,score) value ('1002','A01',79) ;
insert into tb_score (stuId,couId,score) value ('1002','A02',83) ;
insert into tb_score (stuId,couId,score) value ('1002','A03',87) ;

insert into tb_score (stuId,couId,score) value ('1003','A01',65) ;
insert into tb_score (stuId,couId,score) value ('1003','A02',97) ;
insert into tb_score (stuId,couId,score) value ('1003','A03',65) ;

insert into tb_score (stuId,couId,score) value ('1004','A01',78) ;
insert into tb_score (stuId,couId,score) value ('1004','A02',86) ;
insert into tb_score (stuId,couId,score) value ('1004','A03',78) ;

insert into tb_score (stuId,couId,score) value ('1005','A01',67) ;
insert into tb_score (stuId,couId,score) value ('1005','A02',89) ;
insert into tb_score (stuId,couId,score) value ('1005','A03',88) ;

insert into tb_score (stuId,couId,score) value ('1006','A01',98) ;
insert into tb_score (stuId,couId,score) value ('1006','A02',90) ;
insert into tb_score (stuId,couId,score) value ('1006','A03',92) ;

insert into tb_score (stuId,couId,score) value ('1007','A01',85) ;
insert into tb_score (stuId,couId,score) value ('1007','A02',78) ;
insert into tb_score (stuId,couId,score) value ('1007','A03',72) ;

insert into tb_score (stuId,couId,score) value ('1008','A01',78) ;
insert into tb_score (stuId,couId,score) value ('1008','A02',85) ;
insert into tb_score (stuId,couId,score) value ('1008','A03',77) ;

insert into tb_score (stuId,couId,score) value ('1009','A01',68) ;
insert into tb_score (stuId,couId,score) value ('1009','A02',91) ;
insert into tb_score (stuId,couId,score) value ('1009','A03',94) ;

学生表

分数表

班级表

课程表

 

2.1查询各班各科最高分数

SELECT 
    cls.name AS '班级',
    cou.name AS '课程',
    MAX(temp.score) AS '最高分' 
FROM
    (SELECT 
        st.clsId, sc.couId, sc.score
    FROM
        tb_score AS sc
    INNER JOIN tb_student AS st ON sc.stuId = st.stuId) as temp
INNER JOIN tb_class AS cls ON temp.clsId = cls.clsId
INNER JOIN tb_course AS cou ON temp.couId = cou.couId
GROUP BY temp.clsId , temp.couId

 

 

posted @ 2017-05-26 10:47  睡猪遇上狼  阅读(548)  评论(0编辑  收藏  举报