sql server 查询练习
需要建的三个表:
学生表
create table Student
(
Sno varchar(20) not null primary key,
Sname varchar(20) not null,
Ssex varchar(20) not null,
Sbirthday datetime,
Class varchar(20)
)
课程表
create table Course
(
Cno varchar(20) not null primary key,
Cname varchar(20) not null,
Tno varchar(20) not null references Teacher(Tno)
)
成绩表:
create table Score
(
Sno varchar(20) not null references Student(Sno),
Cno varchar(20) not null references Course(Cno),
Degree Decimal(4,1)
)
插入数据:
学生表:
insert into student values (108,'曾华','男',1977-09-01,95033);
insert into student values (105,'匡明','男',1975-10-02,95031);
insert into student values (107,'王丽','女',1976-01-23,95033);
insert into student values (101,'李军','男',1976-01-23,95033);
insert into student values (109,'王芳','女',1975-02-10,95031);
insert into student values (103,'陆君','女',1974-036-03,95031);
课程表:
insert into Course values (3-105,'计算机导论',825);
insert into Course values (3-245,'操作系统',804);
insert into Course values (6-166,'数据电路',856);
insert into Course values (9-888,'高等数学',831);
成绩表:
insert into Score values (103,3-245,86);
insert into Score values (105,3-245,75);
insert into Score values (109,3-245,68);
insert into Score values (103,3-105,92);
insert into Score values (105,3-105,88);
insert into Score values (109,3-105,76);
insert into Score values (101,3-105,64);
insert into Score values (107,3-105,91);
insert into Score values (108,3-105,78);
insert into Score values (101,6-166,85);
insert into Score values (107,6-166,79);
insert into Score values (108,6-166,81);
查询题目:
--1) 查询java 课程比C#分数高的学生
--2)查询平均分成绩大于 70 分的同学的姓名和平均成绩
--3)查询所有同学的学号、姓名、选课数、总成绩
--5)查询没有学过 java 课的学生的学号、姓名
--学过java
--没学过java
--6)查询学过“C#”课程并且也学过“sql”课程的学生的学号、姓名
--7)查询所有课程的平均分、及格率
---8)查询所有课程成绩小于 60 分的同学的学号、姓名、性别
--9)查询没有学全所有课的同学的学号、姓名、性别
--10)查询至少有一门课与学号为“002”的同学所学相同的同学的学号和姓名
--13)查询和“002”号的同学学习的课程完全相同的其他同学学号和姓名
--15)按平均成绩从高到低显示所有学生的“sql”、“java”、“c#”三门的课程 成绩,按如下形式显示:学生 ID,sql,java,c#,有效课程数,有效平均分
--16)查询各科成绩最高和最低的分:以如下形式显示:课程 ID,最高分,最低分
--17)查询不同班级所教不同课程平均分从高到低显示
--18)查询各科成绩前三名的记录:(不考虑成绩并列情况)
/*
row_number() over( order by sc.mark desc)
*/
--19)查询每门课程被选修的学生数
--20)查询出只选修了一门课程的全部学生的学号和姓名
--21)查询男生、女生人数
--22)查询姓“张”的学生名单
--23)查询同名同性学生名单,并统计同名人数
--24)查询每门课程的平均成绩,结果按平均成绩升序排列,平均成绩相同时, 按课程号降序排列
--25)查询平均成绩大于70的所有学生的学号、姓名和平均成绩
--26)检索至少选修两门课程的学生学号
--27)查询两门以上不及格课程的同学的学号及其平均成绩
--28)检索“java”课程分数小于 60,按分数降序排列的同学姓名
查询题目答案:
1:select * from Student stu
left join Score sco on stu.Sno=sco.Sno and sco.Cno=-102
left join Score sco2 on stu.Sno=sco2.Sno and sco2.Cno=-242
where sco.Degree>sco2.Degree; 2:select Sname,AVG(sco.Degree) from Student stu
left join Score sco on stu.Sno=sco.Sno
group by stu.Sname,sco.Sno having AVG(sco.Degree)>70; 3:select stu.Sno,stu.Sname,count(sco.Sno) as '选课数' ,sum(sco.Degree) '总成绩'
from Student stu inner join Score sco on stu.Sno=sco.Sno
group by stu.Sname,stu.Sno,sco.Sno; 5.1:select * from Student where Sno in(select Sno from score where Sno not in (select sno from Score where Cno=-242)); 5.2:select * from Student where Sno in (select Sno from score where Sno in (select sno from Score where Cno=-242)); 6:select * from Student stu
left join Score sco on stu.Sno=sco.Sno and sco.Cno=-102
left join Score sco2 on stu.Sno=sco.Sno and sco2.Cno=-242
where sco.Sno=sco2.Sno; 7:select a.Cno,avg(a.Degree) as 'avg',
CONVERT(float,SUM(case when Degree>0 then 1 else 0 end)) as '总人数',
cONVERT(float,SUM(case when Degree>60 then 1 else 0 end)) as '每门的及格人数',
CONVERT(varchar(20),CONVERT(decimal(18,2),cONVERT(float,SUM(case when Degree>60 then 1.0 else 0.0 end))/
SUM(case when Degree>0 then 1 else 0 end))*100 )+'%'
as '及格率'
from Score a
group by a.Cno 8:select * from Student where Sno in(select Sno from Score where Degree<60); 9:select sco.Sno,stu.Sname,stu.Ssex from Student stu
left join Score sco on stu.Sno=sco.Sno
group by sco.Sno,stu.Sname,stu.Ssex having COUNT(sco.Sno)!=(select COUNT(*) from Course) 10:select * from Student where sno in (select Sno from Score where Cno in (select Cno from Score where Score.Sno=108)); 13:select sco.Sno from Score sco where sco.Sno not in (select Sno from Score where Cno not in (select Cno from Score where Sno=103))
group by sco.Sno having COUNT(*)=(select COUNT(*) from Score where Sno=103)
and sco.Sno<>103 15:select stu.Sno,stu.Sname,
sum(case when sco.cno=-102 then sco.Degree else 0 end) '计算机导论',
sum(case when sco.cno=-160 then sco.Degree else 0 end) '数据电路',
sum(case when sco.cno=-242 then sco.Degree else 0 end) '操作系统',
sum(case when sco.cno=-879 then sco.Degree else 0 end) '高等数学',
COUNT(*) as '有效课程数' ,AVG(sco.Degree) as '有效平均分'
from Student stu
left join Score sco on stu.Sno=sco.Sno
group by stu.Sno,stu.Sname order by AVG(sco.Degree)desc; 16:select Sno,MAX(Degree) as '最高分' ,MIN(Degree) as '最低分' from Score group by Sno; 17:select cou.Cno,stu.Class,avg(sco.Degree)from Score sco
left join Course cou
on sco.Cno=cou.Cno
left join Student stu
on stu.Sno=sco.Sno
group by cou.Cno,stu.Class
order by AVG(sco.Degree) desc; 18:select * from (select *, ROW_NUMBER() over (partition by cno order by Degree desc ) ev from Score sco) t
where t.ev<4 order by t.Cno,t.Degree desc 19:select Sno,COUNT(cno) '选修的课程数' from Score group by Sno; 20:select * from Student stu
left join Score sco on stu.Sno=sco.Sno
where(select COUNT(*) from Score sco2 where sco.Sno=sco2.Sno)=3; 21:select SUM(case when ssex='男' then 1 else 0 end )as '男',
SUM(case when ssex='女' then 1 else 0 end )as '女'
from Student; 22:select * from Student where sname like '张%'; 23:select sname,COUNT(*) from Student group by Sname having COUNT(*)>1; 24:select Cno,AVG(Degree) from Score group by Cno order by AVG(Degree) desc ,Cno ; 25:select Sno,AVG(Degree) as '平均分' from Score group by Sno having AVG(Degree)>70; 26:select sno ,count(Cno) as '选修课程数' from Score group by Sno having COUNT(Cno)>2 or COUNT(Cno)=2 ; 27:select Sno,SUM(Case when Degree<60 then 1 else 0 end ) as '不及格人数' ,
avg(Degree) from Score group by Sno having SUM(Case when Degree<60 then 1 else 0 end )=1; 28:select * from Student stu left join Score sco on stu.Sno=sco.Sno
where Degree>60 and Cno=-242 order by Degree desc ;
sql server 查询练习的更多相关文章
- [转] 利用SET STATISTICS IO和SET STATISTICS TIME 优化SQL Server查询性能
首先需要说明的是这篇文章的内容并不是如何调节SQL Server查询性能的(有关这方面的内容能写一本书),而是如何在SQL Server查询性能的调节中利用SET STATISTICS IO和SET ...
- SQL SERVER 查询性能优化——分析事务与锁(五)
SQL SERVER 查询性能优化——分析事务与锁(一) SQL SERVER 查询性能优化——分析事务与锁(二) SQL SERVER 查询性能优化——分析事务与锁(三) 上接SQL SERVER ...
- SQL Server 查询性能优化 相关文章
来自: SQL Server 查询性能优化——堆表.碎片与索引(一) SQL Server 查询性能优化——堆表.碎片与索引(二) SQL Server 查询性能优化——覆盖索引(一) SQL Ser ...
- 利用SET STATISTICS IO和SET STATISTICS TIME 优化SQL Server查询性能
首先需要说明的是这篇文章的内容并不是如何调节SQL Server查询性能的(有关这方面的内容能写一本书),而是如何在SQL Server查询性能的调节中利用SET STATISTICS IO和SET ...
- 如何找出你性能最差的SQL Server查询
我经常会被反复问到这样的问题:”我有一个性能很差的SQL Server.我如何找出最差性能的查询?“.因此在今天的文章里会给你一些让你很容易找到问题答案的信息向导. 问SQL Server! SQL ...
- 使用WinDbg调试SQL Server查询
上一篇文章我给你介绍了WinDbg的入门,还有你如何能附加到SQL Server.今天的文章,我们继续往前一步,我会向你展示使用WinDbg调试SQL Server查询需要的步骤.听起来很有意思?我们 ...
- sql server 查询分析器消息栏里去掉“(5 行受影响)”
sql server 查询分析器消息栏里去掉"(5 行受影响)" 在你代码的开始部分加上这个命令: set nocount on 记住在代码结尾的地方再加上: set ...
- Sql Server查询性能优化之走出索引的误区
据了解绝大多数开发人员对于索引的理解都是一知半解,局限于大多数日常工作没有机会.也什么没有必要去关心.了解索引,实在哪天某个查询太慢了找到查询条件建个索引就ok,哪天又有个查询慢了,再建立个索引就是, ...
- SQL Server 查询分析器提供的所有键盘快捷方式(转)
下表列出 SQL Server 查询分析器提供的所有键盘快捷方式. 活动 快捷方式 书签:清除所有书签. CTRL-SHIFT-F2 书签:插入或删除书签(切换). CTRL+F2 书签:移动到下一个 ...
- SQL Server查询性能优化——堆表、碎片与索引(二)
本文是对 SQL Server查询性能优化——堆表.碎片与索引(一)的一些总结. 第一:先对 SQL Server查询性能优化——堆表.碎片与索引(一)中的例一的SET STATISTICS IO之 ...
随机推荐
- PL/SQL学习笔记_02_游标
在 PL/SQL 程序中,对于处理多行记录的事务经常使用游标来实现. 为了处理 SQL 语句, ORACLE 必须分配一片叫上下文( context area )的区域来处理所必需的信息,其中包括要处 ...
- JavaWEB - JSP及隐含对象
---------------------------------------------------------------------------------------------------- ...
- OpenCV - Android Studio 中集成Opencv环境(包含opencv_contrib部分)
我在上一篇博客中说到了在Android中集成OpenCV,但是那个版本的OpenCV是没有SIFT和SURF算法的,因为这些算法是受专利保护的,所以并没有被包含在预编译库中,所以如果想要使用SIFT和 ...
- Mybatis学习--Java API
学习笔记,选自Mybatis官方中文文档:http://www.mybatis.org/mybatis-3/zh/java-api.html#directoryStructure 既然你已经知道如何配 ...
- android开发之数据库存取图片
Android数据库中存取图片通常使用两种方式,一种是保存图片所在路径,二是将图片以二进制的形式存储(sqlite3支持BLOB数据类型).对于两种方法的使用,好像第二种方法不如第一种方法更受程序员欢 ...
- tx2在自制载板上无法识别usb以及pcie无法读取数据
注意使用的系统版本是Jetpack-3.1,其它版本的系统上没有测试过!!! 刷机时替换dtb文件: 将Jetpack刷机包 64_TX2/Linux_for_Tegra_tx2/kernel/dtb ...
- JSR-303规范,Bean Validation
一: JSR 303是JAVA EE 6中的一项子规范,叫做Bean Validation,官方参考实现是Hibernate Validator,此实现与Hibernate ORM没有任何关系.JSR ...
- java基础知识(9)---异常
异 常: 异常:就是不正常.程序在运行时出现的不正常情况.其实就是程序中出现的问题.这个问题按照面向对象思想进行描述,并封装成了对象.因为问题的产生有产生的原因.有问题的名称.有问题的描述等多个属性信 ...
- asp.net mvc Partial OutputCache 在SpaceBuilder中的应用实践
最近给SpaceBuilder增加OutputCache 时发现了一些问题,贴在这做个备忘,也方便遇到类似问题的朋友查阅. 目前SpaceBuilder表现层使用是asp.net mvc v1.0,使 ...
- ES6学习之Proxy
定义:“代理器”,用于修改某些操作的默认行为,等同于在语言层面做出修改,所以属于一种“元编程”(meta programming),即对编程语言进行编程.可以对外界的访问进行过滤和改写. 语法: va ...