sql 题目练习
2013-11-09 23:29
253 查看
一:比较简单,查询出销售表中,销售额大于本地区平均水平的记录,用一条sql语句就搞定了。
SELECT * FROM sales s,(SELECT region,AVG(total) avge from sales GROUP BY region) AS avge WHERE s.region=avge.region AND s.total>avge.avge ;
或者Sql语句:
select * from sales as s inner join (select avg(total) as avge,region from sales group by region) avgtable on s.region = avgtable.region where total > avgtable.avge
二:为管理业务培训信息,建立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 s# ,sn from s where S# in(select S# from c,sc where c.c#=sc.c# and cn=’税收基础’)
(2) 使用标准SQL嵌套语句查询选修课程编号为’C2’的学员姓名和所属单位?
答:select sn,sd from s,sc where s.s#=sc.s# and sc.c#=’c2’
(3) 使用标准SQL嵌套语句查询不选修课程编号为’C5’的学员姓名和所属单位?
答:select sn,sd from s where s# not in(select s# from sc where c#=’c5’)
(4)查询选修了课程的学员人数
答:select 学员人数=count(distinct s#) from sc
(5) 查询选修课程超过5门的学员学号和所属单位?
答:select sn,sd from s where s# in(select s# from sc group by s# having count(distinct c#)>5)
三:.有一张person表,有字段id,name,和score.
要求 写一sql语句查询成绩排名前三的同学,包含并列成绩,并序号显示
思路:先把前3名的分数列出来
select distinct score from person order by desc score limit 0,3; //列出分数前三个;
思路二:接下来筛选分数 只要在前三个分数就行。。
select * from person where score in(select distinct score from person order by desc score limit 0,3);
这个语句会报错,具体什么原因求解。。
思路三 :需要对思路二语句进行包装即可。。即把select distinct score from person order by desc score limit 0,3 作为一个表对象
select * from person where score in(select t.score from(select distinct score from person order by score limit 0,3)as t); 这样语句就不报错了。
四:一道SQL语句面试题,关于group by
表内容:
2005-05-09 胜
2005-05-09 胜
2005-05-09 负
2005-05-09 负
2005-05-10 胜
2005-05-10 负
2005-05-10 负
如果要生成下列结果, 该如何写sql语句?
胜 负
2005-05-09 2 2
2005-05-10 1 2
select date,sum(case when shengfu='胜' then 1 else 0 end)'胜',sum(case
when shengfu='负' then 1 else 0 end)'负' from table group by date;
SELECT * FROM sales s,(SELECT region,AVG(total) avge from sales GROUP BY region) AS avge WHERE s.region=avge.region AND s.total>avge.avge ;
或者Sql语句:
select * from sales as s inner join (select avg(total) as avge,region from sales group by region) avgtable on s.region = avgtable.region where total > avgtable.avge
二:为管理业务培训信息,建立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 s# ,sn from s where S# in(select S# from c,sc where c.c#=sc.c# and cn=’税收基础’)
(2) 使用标准SQL嵌套语句查询选修课程编号为’C2’的学员姓名和所属单位?
答:select sn,sd from s,sc where s.s#=sc.s# and sc.c#=’c2’
(3) 使用标准SQL嵌套语句查询不选修课程编号为’C5’的学员姓名和所属单位?
答:select sn,sd from s where s# not in(select s# from sc where c#=’c5’)
(4)查询选修了课程的学员人数
答:select 学员人数=count(distinct s#) from sc
(5) 查询选修课程超过5门的学员学号和所属单位?
答:select sn,sd from s where s# in(select s# from sc group by s# having count(distinct c#)>5)
三:.有一张person表,有字段id,name,和score.
要求 写一sql语句查询成绩排名前三的同学,包含并列成绩,并序号显示
思路:先把前3名的分数列出来
select distinct score from person order by desc score limit 0,3; //列出分数前三个;
思路二:接下来筛选分数 只要在前三个分数就行。。
select * from person where score in(select distinct score from person order by desc score limit 0,3);
这个语句会报错,具体什么原因求解。。
思路三 :需要对思路二语句进行包装即可。。即把select distinct score from person order by desc score limit 0,3 作为一个表对象
select * from person where score in(select t.score from(select distinct score from person order by score limit 0,3)as t); 这样语句就不报错了。
四:一道SQL语句面试题,关于group by
表内容:
2005-05-09 胜
2005-05-09 胜
2005-05-09 负
2005-05-09 负
2005-05-10 胜
2005-05-10 负
2005-05-10 负
如果要生成下列结果, 该如何写sql语句?
胜 负
2005-05-09 2 2
2005-05-10 1 2
select date,sum(case when shengfu='胜' then 1 else 0 end)'胜',sum(case
when shengfu='负' then 1 else 0 end)'负' from table group by date;
相关文章推荐
- 一个关于SQL语句的练习题目
- SQL 练习题目
- 最近练习的一份SQL题目,很经典也有点点水平,给大家瞧瞧
- Oracle SQL 练习题目
- sql练习,题目来源于网络
- SQL查询练习题目
- 数据库sql练习题目
- SQL简单查询语句专项练习
- SQL练习 demo1_select_查询语句
- 工作中一道sql题目的收获
- sql查询语句27到练习
- 杭州启擎的两道sql题目
- 50道经典SQL语句题目及答案(使用Oracle语法)
- PAT练习基础编程题目之多项式求值
- PAT练习基础编程题目之求自定类型元素的平均
- 剑指offer题目练习一
- LeetCode Online Judge 题目C# 练习 - N-Queens
- 几道经典的sql题目
- 偶尔练习一下,go语言做题目
- 一道SQL题目的收录