• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

数据库实验报告

mysql 搞代码 4年前 (2022-01-09) 29次浏览 已收录 0个评论

作者 : 卿笃军 原文地址:http://blog.gaodaima.com/qingdujun/article/details/29028363 使用SQL Server 开发服务器端应用程序 一、实验类别 综合型实验 二、实验目的 熟练掌握后台服务器端应用程序的开发。 三、实验环境 SQL Server 系列的数据库管理系统 四

作者 : 卿笃军

原文地址:http://blog.gaodaima.com/qingdujun/article/details/29028363

使用SQL Server 开发服务器端应用程序 一、实验类别
综合型实验
二、实验目的
熟练掌握后台服务器端应用程序的开发。
三、实验环境
SQL Server 系列的数据库管理系统
四、实验内容
对学生-课程数据库,编写存储过程,完成下面功能:
1.逐条(使用游标)浏览某个系的学生记录;
2.统计任意一门课程的成绩分布情况,即按照各分数段统计人数;
3.统计每个学生的平均成绩及排名;
4.将学生选课成绩从百分制改为等级制(即A、B、C、D、E)显示。
五、实验要求
提交源程序并标识必要的注释。保证程序能正确编译和运行,认真撰写实验报告。
六、实验过程
1.创建数据库及数据表……具体代码及创建后的结果如下图1 所示。
注:以下的3 个表,全部是可视化创建,表初始化内容如下(仿照课本输入的数值),关系
的主码加下划线表示。

学生表:Student(Sno,Sname,Ssex,Sage,Sdept)

课程表:Course(Cno,Cname,Ccredit)

学生课程表:SC(Sno,Cno,Grade)

2.创建存储过程1 完成……功能,具体代码及运行结果如下图R1 所示。

具体代码1:

--1.逐条(使用游标)浏览某个系的学生记录;--DROP PROCEDURE lookDept --删除存储过程-----------存储过程:如下----------------CREATE PROCEDURE lookDept @dept nchar(20) --dept为参数ASDECLARE @sno nchar(15),@sname nchar(20),@sex nchar(2),@age int; --定义DECLARE sp CURSOR FOR --说明游标SELECT Sno,Sname,Ssex ,Sage FROM Student WHERE Sdept = @dept; --查询结果推入缓冲,此时不执行SELECT语句OPEN sp; --打开游标,此时游标指向第一条记录FETCH NEXT FROM sp INTO @sno,@sname ,@sex ,@age; --推进游标WHILE @@fetch_status = 0 --注:= 0 表示执行成功BEGINPRINT @sno+@sname+@sex+convert(nchar,@age)+@dept; --显示FETCH NEXT FROM sp INTO @sno,@sname ,@sex ,@age; --推进游标ENDCLOSE sp; --关闭游标DEALLOCATE sp; --删除游标------------执行操作:如下----------------EXEC lookDept 'CS'; --查询计算机系学生记录

执行结果如图R1:

图:R1

3.创建存储过程2 完成……功能,具体代码及运行结果如下图R2 所示。
具体代码2:

--2.统计任意一门课程的成绩分布情况,即按照各分数段统计人数;--DROP PROCEDURE ScoreSec --删除存储过程-----------存储过程:如下----------------CREATE PROCEDURE ScoreSec @cname nchar(20) --cname为参数ASDECLARE @cno nchar(15); --定义变量SELECT @cno=Cno --通过课程名,查找课程号FROM CourseWHERE Cname=@cnameSELECT @cname 课程名,COUNT(CASE WHEN Grade=60 AND Grade=70 AND Grade=80 AND Grade=90 THEN 1 END) '90分以上'FROM SCWHERE Cno = @cnoGROUP BY Grade;------------执行操作:如下------------------EXEC ScoreSec '数据库'

执行结果如图R2:

图:R2

4.创建存储过程3 完成……功能,具体代码及运行结果如下图R3 所示。
具体代码3:

--3.统计每个学生的平均成绩及排名--DROP PROCEDURE AvgRank --删除存储过程-----------存储过程:如下----------------CREATE PROCEDURE AvgRankASSELECT Sname 姓名,Student.Sno 学号,AVG(Grade) 平均成绩FROM SC,StudentWHERE SC.Sno = Student.Sno --名字查询GROUP BY SC.Sno,Sname,Student.Sno --分组ORDER BY 平均成绩DESC --降排名------------执行操作:如下------------------EXEC AvgRank

执行结果如图R3:

图:R3

5.创建存储过程4 完成……功能,具体代码及运行结果如下图R4 所示
具体代码4:

--4.将学生选课成绩从百分制改为等级制(即A、B、C、D、E)显示。--DROP PROCEDURE Rank100 --删除存储过程-----------存储过程:如下----------------CREATE PROCEDURE Rank100ASSELECT Sname 姓名,SC.Sno 学号,Cname 课程名,(CASEWHEN Grade=60 AND Grade=70 AND Gr<p>本文来源gao!%daima.com搞$代*!码9网(</p>ade=80 AND Grade=90 THEN 'A' END) 等级FROM SC,Student,CourseWHERE SC.Sno = Student.Sno AND SC.Cno = Course.Cno --姓名,课程名查询------------执行操作:如下------------------EXEC Rank100

执行结果如图R4:

图:R4

七、实验总结

这2 周来,一直忙忙碌碌于各种事物,数据库作业一直拖到今天早上才开始写。按照作业要求,踏踏实实,一步一步的,将功能全部实现了。功能实现期间,查阅了不少互联网资料,当然课本也来来回回的翻阅了好几遍,没办法,自己实在是弱的可以。期间,主要查阅的关键字SQL ,CASE, WHEN, AVG 当然还有游标。完成期间,主要遇到的问题主要是以下几个:
存储结构1:Print 不显示任何东西
解决:原来是我游标说明处的SELECT 语句写错了。
错误:

DECLARE sp CURSOR FOR --说明游标SELECT @Sno,@Sname,@Ssex ,@Sage FROM Student WHERE Sdept = @dept; --查询结果推入缓冲,此时不执行SELECT 语句

正确:

DECLARE sp CURSOR FOR --说明游标SELECT Sno,Sname,Ssex ,Sage FROM Student WHERE Sdept = @dept; --查询结果推入缓冲,此时不执行SELECT 语句

存储结构2:主要遇到的问题就是代码如何简化问题。我上网搜索了CASE WHEN等的用法。
主要学习到的内容:(注:以下参考eshizhan的博客园)
CASE 主要有2种表达形式
1)简单CASE函数:

CASE sexWHEN '1' THEN '男'WHEN '2' THEN '女'ELSE '其他' END

2)CASE搜索函数:

CASEWHEN sex = '1' THEN '男'WHEN sex = '2' THEN '女'ELSE '其他' END

存储结构3:主要是聚集函数,分组的问题。
由于我想显示姓名,学号,平均分,于是以下代码就出现了:

SELECT Sname 姓名,Student.Sno 学号,AVG(Grade) 平均成绩

问题出现了:分析语句没问题,但是执行语句的时候,老是提示这样的错误“选择列表中的列'Student.Sname' 无效,因为该列没有包含在聚合函数或GROUP BY 子句中。”
解决方法:
于是我分组的时候,将其全部包含进去了,机智啊。

GROUP BY SC.Sno,Sname,Student.Sno --分组

存储结构4:这个基本上没遇到什么问题,很容易。

设想与建议:其实,如果有时间,我想做一个界面版的查询~~~还是时间紧得很啊!!!只能等到课设的时候了。另外就是,由于我电脑上面安装的是wps,为了避免用office打开的时候,格式改变影响阅读,我将文档导成.pdf格式,便于阅读。

本报告SQL Server数据库下载:http://pan.baidu.com/s/1gdABS4N 密码:14io


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:数据库实验报告

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址