【SQL Server数据库】简单查询

目录

用SQL语句完成下列查询。使用数据库为SCHOOL数据库

[1. 查询学生的姓名、性别、班级名称,并把结果存储在一张新表中。](#1. 查询学生的姓名、性别、班级名称,并把结果存储在一张新表中。)

[2. 查询男生的资料。](#2. 查询男生的资料。)

[3. 查询所有计算机系的班级信息。](#3. 查询所有计算机系的班级信息。)

4.查询艾老师所教的课程号。

[5. 查询年龄小于30岁的女同学的学号和姓名。](#5. 查询年龄小于30岁的女同学的学号和姓名。)

[6. 查询所有被选修的课程号。](#6. 查询所有被选修的课程号。)

7.在学生基本信息表Student中检索学生的姓名和出生年份,输出的列名为STUDENT_NAME和BIRTH_YEAR。

8.在StudnetGrade中,求选修课程"0511"且分数排名为前10%学生的学号和得分。

9.查询选修课程号为"0109"或"0111"的学生学号。

10.查询课程"0101"的成绩在80与90之间的同学的学号。

11.查询平均成绩都在80分以上的学生学号及平均成绩。


用SQL语句完成下列查询。使用数据库为SCHOOL数据库

1. 查询学生的姓名、性别、班级名称,并把结果存储在一张新表中。

Sql语句:

sql 复制代码
select Stu_name,Stu_sex,Class_name
into Stu_Cla
from Student s left outer join Class c
on s.Class_id = c.Class_id;

运行结果:

2. 查询男生的资料。

Sql语句:

sql 复制代码
select * from Student where Stu_sex = '男';

运行结果:

3. 查询所有计算机系的班级信息。

Sql语句:

sql 复制代码
/*连接查询*/
select c.*
from Class c,
     Deparment d
where d.Depar_name = '计算机系'
  and d.Depar_id = c.Depar_id;

/*子查询*/
select *
from Class
where Depar_id = (select Depar_id from Deparment where Depar_name = '计算机系');

运行结果:

4.查询艾老师所教的课程号。

Sql语句:

sql 复制代码
/*可能有多位艾老师,模糊查询;也可能教多门课程,distinct去重*/
select distinct Course_id
from Teacher t,
     CourseTeacher ct
where t.Teac_name like '艾%'
  and t.Teac_id = ct.Teac_id;

运行结果:

5. 查询年龄小于30岁的女同学的学号和姓名。

(获取系统当前时间函数:getdate(),获取时间的年份函数:year,获取月份函数:month,获取"日"函数:day)

Sql语句:

sql 复制代码
select Stu_id, Stu_name
from Student
where year(getdate()) - year(Birthday) < 30
  and Stu_sex = '女';

运行结果:

6. 查询所有被选修的课程号。

Sql语句:

sql 复制代码
/*有学生成绩的就是被选修了的,注意去重*/
select distinct Course_id from StudentGrade;

运行结果:

7.在学生基本信息表Student中检索学生的姓名和出生年份,输出的列名为STUDENT_NAME和BIRTH_YEAR。

Sql语句:

sql 复制代码
select Stu_name STUDENT_NAME, year(Birthday) BIRTH_YEAR
from Student;

运行结果:

8.在StudnetGrade中,求选修课程"0511"且分数排名为前10%学生的学号和得分。

(Top 10 percent)

Sql语句:

sql 复制代码
select top 10 percent Stu_id, Grade
from StudentGrade
where Course_id = '0511'
order by Grade desc;

运行结果:

9.查询选修课程号为"0109"或"0111"的学生学号。

Sql语句:

sql 复制代码
select distinct Stu_id
from StudentGrade
where Course_id in ('0109', '0111');

运行结果:

10.查询课程"0101"的成绩在80与90之间的同学的学号。

Sql语句:

sql 复制代码
select Stu_id
from StudentGrade
where Course_id = '0101'
  and Grade between 80 and 90;

运行结果:

11.查询平均成绩都在80分以上的学生学号及平均成绩。

(group by)

Sql语句:

sql 复制代码
select Stu_id, avg(Grade) avgGrade
from StudentGrade
group by Stu_id
having avg(Grade) > 80;

运行结果:

相关推荐
十五年专注C++开发37 分钟前
hiredis: 一个轻量级、高性能的 C 语言 Redis 客户端库
开发语言·数据库·c++·redis·缓存
bianguanyue2 小时前
SQLite密码修改故障排查:RSA加密随机性导致的数据库匹配问题
数据库·sqlite·c#
亚马逊云开发者2 小时前
将 Go 应用从 x86 平台迁移至 Amazon Graviton:场景剖析与最佳实践
linux·数据库·golang
张先shen3 小时前
亿级流量下的缓存架构设计:Redis+Caffeine多级缓存实战
数据库·redis·缓存
~ 小团子3 小时前
每日一SQL 【各赛事的用户注册率】
数据库·sql
llm2009094 小时前
Jmeter的JDBC数据库连接
数据库·jmeter
betazhou4 小时前
SQL server之版本的初认知
数据库·oracle·goldengate·sql server·ogg·gdr
superonion06204 小时前
【DB2】load报错SQL3501W、SQL3109N、SQL2036N
数据库
~ 小团子4 小时前
每日一SQL 【每月交易 I】
数据库·sql
apihz5 小时前
VM虚拟机全版本网盘+免费本地网络穿透端口映射实时同步动态家庭IP教程
android·服务器·开发语言·网络·数据库·网络协议·tcp/ip