最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

项目3 利用存储过程-操作学生成绩信息表

来源:动视网 责编:小OO 时间:2025-10-02 00:10:36
文档

项目3 利用存储过程-操作学生成绩信息表

项目3利用存储过程操作学生成绩信息表一、目的与要求1.利用存储过程创建库表2.掌握排序和查询的使用3.掌握如何调用存储过程进行带参数查询二、内容要求学生成绩信息三个表,结构如下:学生表:Member字段名称数据类型说明MIDChar(10)学生号,主键MNameChar(50)姓名课程表:字段名称数据类型说明FIDChar(10)课程,主键FNameChar(50)课程名成绩表:Score字段名称数据类型说明SIDint自动编号,主键,成绩记录号FIDChar(10)课程号,外键MIDChar
推荐度:
导读项目3利用存储过程操作学生成绩信息表一、目的与要求1.利用存储过程创建库表2.掌握排序和查询的使用3.掌握如何调用存储过程进行带参数查询二、内容要求学生成绩信息三个表,结构如下:学生表:Member字段名称数据类型说明MIDChar(10)学生号,主键MNameChar(50)姓名课程表:字段名称数据类型说明FIDChar(10)课程,主键FNameChar(50)课程名成绩表:Score字段名称数据类型说明SIDint自动编号,主键,成绩记录号FIDChar(10)课程号,外键MIDChar
项目3 利用存储过程操作学生成绩信息表

一、目的与要求

1.利用存储过程创建库表

2.掌握排序和查询的使用

3.掌握如何调用存储过程进行带参数查询

二、内容要求

学生成绩信息三个表,结构如下: 

学生表:Member

字段名称数据类型说明
MIDChar(10)学生号,主键
MNameChar(50)姓名
课程表:

字段名称数据类型说明
FIDChar(10)课程,主键
FNameChar(50)课程名
成绩表:Score

字段名称数据类型说明
SIDint自动编号,主键,成绩记录号
FIDChar(10)课程号,外键
MIDChar(10)学生号,外键
Scoreint成绩
请编写T-SQL语句来实现如下功能:

1)查询各个学生语文、数学、英语、历史课程成绩,例如下表:

姓名语文数学英语历史
张萨78  6776
王强 

 67 84 96
李三70 87 92 56
李四 

8078 9766
2)查询四门课中成绩低于70分的学生及相对应课程名和成绩。

3)统计各个学生参加考试课程的平均分,且按平均分数由高到底排序。

4)创建存储过程,分别查询参加1、2、3、4门考试及没有参加考试的学生名单,要求显示姓名、学号。

三、建表语句:

USE master

GO

/*$$$$$$$$$$$$$建库$$$$$$$$$$$$$$$$$$$$$$$$*/

--检验数据库是否存在,如果为真,删除此数据库--

IF exists(SELECT * FROM sysdatabases WHERE name='Student')

  DROP DATABASE Student

GO

CREATE DATABASE Student

GO

--建数据表--

USE Student

GO

CREATE TABLE Member  --学生表

(

  MID  char(10) primary key,  --学生号

  MName  CHAR(50) NOT NULL  --姓名

)

GO

CREATE TABLE F  --课程表

(

 FID   char(10) primary key,    --课程号

FName  CHAR(50) NOT NULL --课程名

)

GO

CREATE TABLE score  --学生成绩表

(

  SID int identity(1,1) primary key,  --成绩记录号

  FID char(10)  foreign key(FID) references F(FID) ,     --课程号

  MID char(10)  foreign key(MID) references Member(MID) ,     --学生号

  Score  int NOT NULL    --成绩

)

GO

--课程表中插入数据--

INSERT INTO F(FID,FName)VALUES('F001','语文')

INSERT INTO F(FID,FName)VALUES('F002','数学')

INSERT INTO F(FID,FName)VALUES('F003','英语')

INSERT INTO F(FID,FName)VALUES('F004','历史')

--学生表中插入数据--

INSERT INTO Member(MID,MName)VALUES('M001','张萨')

INSERT INTO Member(MID,MName)VALUES('M002','王强')

INSERT INTO Member(MID,MName)VALUES('M003','李三')

INSERT INTO Member(MID,MName)VALUES('M004','李四')

INSERT INTO Member(MID,MName)VALUES('M005','阳阳')

INSERT INTO Member(MID,MName)VALUES('M006','虎子')

INSERT INTO Member(MID,MName)VALUES('M007','夏雪')

INSERT INTO Member(MID,MName)VALUES('M008','璐璐')

INSERT INTO Member(MID,MName)VALUES('M009','珊珊')

INSERT INTO Member(MID,MName)VALUES('M010','香奈儿')

--成绩表中插入数据--

INSERT INTO Score(FID,MID,Score)VALUES('F001','M001',78)

INSERT INTO Score(FID,MID,Score)VALUES('F002','M001',67)

INSERT INTO Score(FID,MID,Score)VALUES('F003','M001',)

INSERT INTO Score(FID,MID,Score)VALUES('F004','M001',76)

INSERT INTO Score(FID,MID,Score)VALUES('F001','M002',)

INSERT INTO Score(FID,MID,Score)VALUES('F002','M002',67)

INSERT INTO Score(FID,MID,Score)VALUES('F003','M002',84)

INSERT INTO Score(FID,MID,Score)VALUES('F004','M002',96)

INSERT INTO Score(FID,MID,Score)VALUES('F001','M003',70)

INSERT INTO Score(FID,MID,Score)VALUES('F002','M003',87)

INSERT INTO Score(FID,MID,Score)VALUES('F003','M003',92)

INSERT INTO Score(FID,MID,Score)VALUES('F004','M003',56)

INSERT INTO Score(FID,MID,Score)VALUES('F001','M004',80)

INSERT INTO Score(FID,MID,Score)VALUES('F002','M004',78)

INSERT INTO Score(FID,MID,Score)VALUES('F003','M004',97)

INSERT INTO Score(FID,MID,Score)VALUES('F004','M004',66)

INSERT INTO Score(FID,MID,Score)VALUES('F001','M006',88)

INSERT INTO Score(FID,MID,Score)VALUES('F002','M006',55)

INSERT INTO Score(FID,MID,Score)VALUES('F003','M006',86)

INSERT INTO Score(FID,MID,Score)VALUES('F004','M006',79)

INSERT INTO Score(FID,MID,Score)VALUES('F002','M007',77)

INSERT INTO Score(FID,MID,Score)VALUES('F003','M008',65)

INSERT INTO Score(FID,MID,Score)VALUES('F004','M007',48)

INSERT INTO Score(FID,MID,Score)VALUES('F004','M009',75)

INSERT INTO Score(FID,MID,Score)VALUES('F002','M009',88)
四、附标准答案:

"

-- 1)查询各个学生语文、数学、英语、历史课程成绩--

SELECT Member.MName AS 姓名,

英语 = SUM(CASE F.FName WHEN '语文' THEN Score.Score END), 

数学 = SUM(CASE F.FName WHEN '数学' THEN Score.Score END), 

语文 = SUM(CASE F.FName WHEN '英语' THEN Score.Score END), 

历史 = SUM(CASE F.FName WHEN '历史' THEN Score.Score END) 

FROM Score, Member,F 

WHERE F.FID = Score.FID AND Member.MID =Score.MID GROUP BY Member.MName 

-- 2)查询四门课中成绩低于70分的学生及相对应课程名和成绩--

select 姓名=(select MName from Member where MID=Score.MID),课程名=(select FName from F where FID=Score.FID),成绩=Score from Score where Score<70

-- 3)统计各个学生四课程的平均分,且按平均分数由高到底排序--

select 姓名=(select MName from Member where MID=Score.MID),平均分=Avg(Score) from Score group by MID order by 平均分 desc

-- 4)创建存储过程--

if exists (select * from sysobjects where name='P_stu')

drop procedure P_stu

GO

create procedure P_stu

@num int

As

print'参加'+convert(varchar(5),@num)+'门课考试的学生姓名及学号:'

select 姓名=(select MName from Member where MID=Score.MID),学号=MID from Score group by MID having count(*)=@num 

--调用存储过程--

exec P_stu @num=2

文档

项目3 利用存储过程-操作学生成绩信息表

项目3利用存储过程操作学生成绩信息表一、目的与要求1.利用存储过程创建库表2.掌握排序和查询的使用3.掌握如何调用存储过程进行带参数查询二、内容要求学生成绩信息三个表,结构如下:学生表:Member字段名称数据类型说明MIDChar(10)学生号,主键MNameChar(50)姓名课程表:字段名称数据类型说明FIDChar(10)课程,主键FNameChar(50)课程名成绩表:Score字段名称数据类型说明SIDint自动编号,主键,成绩记录号FIDChar(10)课程号,外键MIDChar
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top