热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

数据库实验报告

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

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

作者 : 卿笃军

原文地址:http://blog.csdn.net/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为参数
AS
DECLARE @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 表示执行成功
BEGIN
PRINT @sno+@sname+@sex+convert(nchar,@age)+@dept; --显示
FETCH NEXT FROM sp INTO @sno,@sname ,@sex ,@age; --推进游标
END
CLOSE sp; --关闭游标
DEALLOCATE sp; --删除游标
------------执行操作:如下----------------
EXEC lookDept 'CS'; --查询计算机系学生记录
执行结果如图R1:
\

图:R1

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

--2.统计任意一门课程的成绩分布情况,即按照各分数段统计人数;
--DROP PROCEDURE ScoreSec --删除存储过程
-----------存储过程:如下----------------
CREATE PROCEDURE ScoreSec @cname nchar(20) --cname为参数
AS
DECLARE @cno nchar(15); --定义变量
SELECT @cno=Cno --通过课程名,查找课程号
FROM Course
WHERE Cname=@cname
SELECT @cname 课程名,COUNT(CASE WHEN Grade<60 THEN 1 END) &#39;60分以下&#39;,
COUNT(CASE WHEN Grade>=60 AND Grade<70 THEN 1 END) &#39;60分-70分&#39;,
COUNT(CASE WHEN Grade>=70 AND Grade<80 THEN 1 END) &#39;70分-80分&#39;,
COUNT(CASE WHEN Grade>=80 AND Grade<90 THEN 1 END) &#39;80分-90分&#39;,
COUNT(CASE WHEN Grade>=90 THEN 1 END) &#39;90分以上&#39;
FROM SC
WHERE Cno = @cno
GROUP BY Grade;
------------执行操作:如下----------------
--EXEC ScoreSec &#39;数据库&#39;
执行结果如图R2:
\

图:R2

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

--3.统计每个学生的平均成绩及排名
--DROP PROCEDURE AvgRank --删除存储过程
-----------存储过程:如下----------------
CREATE PROCEDURE AvgRank
AS
SELECT Sname 姓名,Student.Sno 学号,AVG(Grade) 平均成绩
FROM SC,Student
WHERE 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 Rank100
AS
SELECT Sname 姓名,SC.Sno 学号,Cname 课程名,(CASE
WHEN Grade<60 THEN &#39;E&#39;
WHEN Grade>=60 AND Grade<70 THEN &#39;D&#39;
WHEN Grade>=70 AND Grade<80 THEN &#39;C&#39;
WHEN Grade>=80 AND Grade<90 THEN &#39;B&#39;
WHEN Grade>=90 THEN &#39;A&#39; END) 等级
FROM SC,Student,Course
WHERE 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 sex
WHEN &#39;1&#39; THEN &#39;男&#39;
WHEN &#39;2&#39; THEN &#39;女&#39;
ELSE &#39;其他&#39; END
2)CASE搜索函数:
CASE
WHEN sex = &#39;1&#39; THEN &#39;男&#39;
WHEN sex = &#39;2&#39; THEN &#39;女&#39;
ELSE &#39;其他&#39; END
存储结构3:主要是聚集函数,分组的问题。
由于我想显示姓名,学号,平均分,于是以下代码就出现了:
SELECT Sname 姓名,Student.Sno 学号,AVG(Grade) 平均成绩
问题出现了:分析语句没问题,但是执行语句的时候,老是提示这样的错误“选择列表中的列&#39;Student.Sname&#39; 无效,因为该列没有包含在聚合函数或GROUP BY 子句中。”
解决方法:
于是我分组的时候,将其全部包含进去了,机智啊。
GROUP BY SC.Sno,Sname,Student.Sno --分组
存储结构4:这个基本上没遇到什么问题,很容易。

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

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


推荐阅读
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • CentOS 7 磁盘与文件系统管理指南
    本文详细介绍了磁盘的基本结构、接口类型、分区管理以及文件系统格式化等内容,并提供了实际操作步骤,帮助读者更好地理解和掌握 CentOS 7 中的磁盘与文件系统管理。 ... [详细]
  • 探讨如何通过编程技术实现100个并发连接,解决线程创建顺序问题,并提供高效的并发测试方案。 ... [详细]
  • 本周信息安全小组主要进行了CTF竞赛相关技能的学习,包括HTML和CSS的基础知识、逆向工程的初步探索以及整数溢出漏洞的学习。此外,还掌握了Linux命令行操作及互联网工作原理的基本概念。 ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 本文介绍了如何在具备多个IP地址的FTP服务器环境中,通过动态地址端口复用和地址转换技术优化网络配置。重点讨论了2Mb/s DDN专线连接、Cisco 2611路由器及内部网络地址规划。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 创建第一个 MUI 移动应用项目
    本文将详细介绍如何使用 HBuilder 创建并运行一个基于 MUI 框架的移动应用项目。我们将逐步引导您完成项目的搭建、代码编写以及真机调试,帮助您快速入门移动应用开发。 ... [详细]
  • 梦幻西游挖图奇遇:70级项链意外触发晶清诀,3000W轻松到手
    在梦幻西游中,挖图是一项备受欢迎的活动,无论是小宝图还是高级藏宝图,都吸引了大量玩家参与。通常情况下,小宝图的数量保证了稳定的收益,但特技装备的出现往往能带来意想不到的惊喜。本文讲述了一位玩家通过挖图获得70级晶清项链的故事,最终实现了3000W的游戏币逆袭。 ... [详细]
  • 本文探讨了 RESTful API 和传统接口之间的关键差异,解释了为什么 RESTful API 在设计和实现上具有独特的优势。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 网络攻防实战:从HTTP到HTTPS的演变
    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
author-avatar
莫莫2602891683
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有