《数据库课程设计报告-校运动会管理系统(共15页).doc》由会员分享,可在线阅读,更多相关《数据库课程设计报告-校运动会管理系统(共15页).doc(15页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上数据库课程设计报告运动会数据库系统目录0专心-专注-专业第一章 系统概述1.1系统开发背景与意义1.1.1系统开发背景高等院校运动会是高校体育工作的重要组成部分。近年来,随着招生规模的扩大, 导致比赛项目、参赛人数不断增加,同时人们对比赛结果的准确性和实时性要求也越来越高,参赛队需要得到及时、准确的相关信息 ,从而有效进行竞赛的决策指导,这些问题和需求是采用人工方式或单机版运动会管理系统都难以解决的。为此,我们对运动会的信息综合管理系统进行了研究,使运动会的筹备、组织、管理、协调等工作全面实现了计算机网络化、自动化,极大的提高了工作效率和信息处理的实时性。高校运动会作
2、为各项体育运动的基础,具有广泛的群众性。每届的高校运动会声势浩大,是提高、检验学生的健康水平,开展全民健身运动的有效途径。由于比赛项目较多,参赛人数广,数据处理量大且变化时效性要求高,管理较为复杂,其编排,记录,公告工作是一项复杂的工程。为了解决在运动会管理和组织所面临的各种问题,我们开发了一套适合高校的运动会管理系统。在分析运动会管理需求的基础上,通过比较分析不 同的开发模式和特点,系统采用简单实用的Windows环境下的基于浏览器/服务器的模式构建,用SQL Server2008作为后台数据库,提供对数据库的查询、添加、修改、删除等操作来实现信息网上管理,并对信息管理功能进行了详细的分析,
3、以实现动态、交互、高效的网络化信息管理。系统能够对运动员的报名信息进行准确统计,能够有效处理赛程中的实时数据。1.1.2系统开发意义本次为学校举行的田径运动会设计运动会管理系统。要求对运动员(包括比赛项目和比赛成绩),比赛项目的设置,裁判判罚比赛,后勤人员和宣传组的相关工作等进行管理。具体来讲,田径运动会包括若干个比赛项目,由学校设置比赛项目和比赛规则,运动员根据比赛规则报名参赛,裁判对运动员的比赛进行记录,运动员参加比赛,由裁判评定和处理成绩,但须公平公正。通过课程设计,让我们能够全面了解数据库应用系统的整个开发过程,验证课堂教学中的理论,掌握数据库系统的基本概念,基本原理及应用技术,掌握S
4、QL语言的定义和各种操作能力,进一步掌握SQL语言的数据库编程技能,学会利用课堂上已学过的数据库知识进行数据库设计,使学生对开发信息管理系统有一个总体认识,可使学生得到很好的锻炼,为以后学习、工作打下很好的基础。第二章 系统需求分析21 需求分析概述本数据库系统适用于各种学校田径运动会的全程管理。本系统竞赛规程设置灵活,输入运动员报名表方便,秩序册自动生成,成绩录入方便快捷,成绩查询功能丰富。2.2.1功能需求分析(1) 该系统是田径运动会比赛期间的信息处理系统,同时也是对外发布信息的窗口。赛会管理人员可以通过发布比赛信息,如比赛准备期间的比赛规则,比赛项目流程信息,比赛期间的各个比赛实时信息
5、等。(2) 提供报名功能。运动员的报名信息是一届运动会的关键信息,因此,要给运动员提供一个方便快捷的方式进行报名操作。(3) 运动会期间要进行比赛成绩,排名等信息的录入和发布的操作。(4) 运动会期间会有后勤组对运动员进行服务,运动会信息管理将会给出各个后勤小组的相关分工。(5)比赛结束后,要为运动会信息管理提供各个比赛项目信息的查询,统计功能,并且将统计结果生成文档,打印为报表。2.2.2 可行性分析可行性分析也称可行性研究,是决策部门在采取一项重大改革或投资行动之前,对该项目的必要性和可能性进行分析与论证的活动,具体可以对几下方面分析:1、技术可行性分析运动会管理需求的基础上,通过比较分析
6、不同的开发模式和特点,系统采用简单实用的Windows环境下的基于浏览器/服务器的模式构建,用SQL Server2008作为后台数据库,提供对数据库的查询、添加、修改、删除等操作来实现信息网上管理,并对信息管理功能进行了详细的分析,以实现动态、交互、高效的网络化信息管理。该数据库的开发是具有可行性的。2、经济可行性只需要一台PC机,需要的支持软件较少,软件投入应用时也不需要很高配置的计算机设备和网络的安装,软件的运行寿命比较长,成本低,所以开发该系统有经济可行性。3、管理可行性新的运动会管理数据库系统充分发挥了计算机技术、网络技术的强大功能,从整体上改善了运动会的管理工作,提高了运动会服务的
7、功能和质量,实现了运动会信息管理系统的的信息化、网络化、自动化。通过对经济、技术、管理可行性的充分研究,确定了运动会管理系统的开发是必要的、可行的。综上所述,开发该小型运动会管理数据库系统是非常可行的。22 系统数据流图数据流图(Data Flow Diagram):简称DFD,它从数据传递和加工角度,以图形方式来表达系统的逻辑功能、数据在系统内部的逻辑流向和逻辑变换过程,是的主要表达工具及用于表示模型的一种图示方法。数据流图是软件设计人员和用户之间很好的通信工具。首先,要输入各个参赛运动员的报名表,并建立相关的数据库;在运动会比赛过程中,要求及时的输入各个运动员比赛项目的成绩并进行相应的出理
8、,打印出成绩报表,提供各个运动会信息的查询。1 登记 报名报名 分道分组表运动员 报名信息项目信息 输出0 注册登记运动员姓名编号对照表 输出参赛注册输出输出成绩比赛名次2 进行 比赛学生 参赛生成项目成绩生成3 进行复赛、决赛成绩名次名单学院成绩4输出成绩信息各 类 报 表 赛程安排数据流图2.5数据字典数据结构编号数据结构名含义说明组成01报名表记录运动员的相关信息姓名,性别,学号,运动员编号,所在院系,参加项目02比赛项目表记录学校设置的比赛项目情况比赛编号,项目名称,比赛类型,预赛时间,决赛时间03裁判表记录裁判信息和判罚相关比赛的信息裁判编号,性别,姓名,等级,比赛编号04后勤组表记
9、录后期工作人员的工作情况值班编号,值班人数,值班时间05宣传组表记录宣传组的对投稿的宣传情况作者姓名,作者院系,文章名称,作者学号06学院表记录学院排名的情况学院名,排名07项目成绩表记录各个项目的最后比赛结果信息运动员编号,项目编号,项目名称,预赛排名,决赛排名,是否破记录对上述10种数据定义如下:(1)报名表数据项编号数据项名含义说明名称数据类型数据长度取值范围1姓名运动员的全称YDY_nameVARCHAR20任何汉字2性别运动员性别YDY_sexVARCHAR2男或女3运动员编号班级的全称YDY_num VARCHAR8任何汉字4所在院系运动员的所在院系YDY_xymVARCHAR20
10、任何汉字(2)比赛项目表数据项编号数据项名含义说明名称数据类型数据长度取值范围1项目编号项目的编号情况BSBHVARCHAR5数字2比赛名称比赛的全称BSMCVARCHAR20任何汉字3比赛类别记录项目的类型BSLBVARCHAR20任何汉字4预赛比赛时间记录项目的比赛预赛时间BSSJ_ys日期型-5决赛比赛时间记录项目的比赛决赛的时间BSSJ_js 日期型-(3)裁判表数据项编号数据项名含义说明名称数据类型数据长度取值范围1裁判编号辨别裁判的唯一标识CPBHVARCHAR5数字2性别裁判性别CPXBVARCHAR2男或女3姓名裁判名字BSLBVARCHAR20任何汉字4等级裁判的专业等级CP
11、XM VARCHAR10任何汉字(4)后勤组表数据项编号数据项名含义说明名称数据类型数据长度取值范围1值班编号唯一辨别值班小组的标识ZBBH VARCHAR5数字2值班人姓名值班人姓名ZBRXMvarchar5数字3值班时间值班的时段ZBSDVARCHAR20任何汉字(5)宣传组表数据项编号数据项名含义说明名称数据类型数据长度取值范围1作者姓名投稿人姓名 ZZXMVARCHAR5任何汉字2作者院系投稿人所在院系ZZYXVARCHAR20任何汉字3作者学号投稿人身为学生的学号ZZXHVARCHAR20任何汉字(6)学院表数据项编号数据项名含义说明名称数据类型数据长度取值范围1学院名学院的全称XY
12、MVARCHAR20任何汉字2学院排名学院在比赛中的排名XYPMVARCHAR20任何汉字(7)项目成绩表项目成绩(运动员编号,比赛编号,项目名称,预赛排名,决赛排名,是否破纪录)3NF数据项编号数据项名含义说明名称数据类型数据长度取值范围1运动员编号运动员比赛的唯一标识YDY_bhVARCHAR20数字2比赛编号运动员参加比赛的编号YDY_bsbhVARCHAR20数字3项目名称项目的全称YDY_bsmcVARCHAR20任何汉字4预赛排名记录运动员在预赛中取得的排名YDY_ysplVARCHAR5汉字或数字5决赛排名记录运动员在决赛中取得的排名YDY_jsplVARCHAR5汉字或数字6破
13、纪录查看运动员是否破纪录PJLVARCHAR2是或否(8)预赛表数据项编号数据项名含义说明名称数据类型数据长度取值范围1运动员编号运动员的编号YS_bh VARCHAR20任何汉字2比赛编号运动员参加比赛的编号YS_bsmcVARCHAR20任何汉字(9)决赛表数据项编号数据项名含义说明名称数据类型数据长度取值范围1运动员编号运动员的编号YS_bh VARCHAR20任何汉字2比赛编号运动员参加比赛的编号YS_bsmcVARCHAR20任何汉字(10)后勤表数据项编号数据项名含义说明名称数据类型数据长度取值范围1值班编号值班编号ZBBH VARCHAR5任何汉字2值班人姓名编号值班人姓名编号Z
14、BMXMVARCHAR20任何汉字(11)主持表数据项编号数据项名含义说明名称数据类型数据长度取值范围1裁判编号裁判编号CPBH VARCHAR5任何汉字2比赛编号比赛编号BSBHVARCHAR5任何汉字(12)服务表数据项编号数据项名含义说明名称数据类型数据长度取值范围1值班编号值班编号ZBBH VARCHAR5任何汉字2运动员编号运动员编号YDY_numVARCHAR5任何汉字第三章 系统总体设计3.1 系统概念设计3.1.1 概念模型(E-R图)值班姓名值班编号预赛排名项目编号后勤组运动员编号决赛排名运动员编号项目名称m服务性别是否破纪录姓名p比赛成绩n学院运动员1获得n比赛编号k项目名
15、称主持类别决赛时间宣传工作1宣传m1预赛时间比赛项目m注册参赛p1学生nm派遣作者学号作者姓名作者院系1m1编号裁判学院等级性别姓名学院排名学院名3.1.2关系模式(1) 实体转化的关系模式运动员(姓名,性别,运动员编号,所在院系)3NF比赛项目(比赛类型,比赛编号,项目名称,预赛时间,决赛时间)3NF裁判员(裁判编号,姓名,性别,裁判等级)3NF后勤组(值班编号,值班人姓名)3NF值班安排(值班编号,值班时间)3NF宣传组(作者学号,作者姓名,作者院系)3NF学院(学院名,学院排名)3NF项目成绩(运动员编号,比赛编号,项目名称,预赛排名,决赛排名,是否破纪录)3NF预赛(运动员编号,比赛编
16、号) 3NF决赛(运动员编号,比赛编号) 3NF主持(裁判编号,比赛编号) 3NF服务(值班编号,运动员编号) 3NF第四章 数据库定义和数据安全性与完整性定义4.1定义数据库模式的SQL操作在以下的sql语句中,每个关系表都给出了相应的主键和外键,个别属性给出了check约束,并考虑引用完整性,保证的数据库的安全性和完整性定义。create database shujukucreate table athlete /*-运动员-*/(YDY_name VARCHAR(20) NOT NULL, /*运动员姓名*/YDY_sex VARCHAR(2) NOT NULL CHECK(YDYXB
17、in(男,女), -运动员性别YDY_num VARCHAR(8) CONSTRAINT NUM_PK PRIMARY KEY, -运动员编号YDY_xym VARCHAR(20) REFERENCES xueyuan(XYM), -学院名 维护引用完整性ON DELETE SET NULLON UPSET CASECADE )go create table BSXM /*-比赛项目-*/(BSBH VARCHAR(5) PRIMARY KEY , -比赛编号BSMC VARCHAR(20) NOT NULL, -比赛名称BSLB VARCHAR(20) NOT NULL, -比赛类别BSSJ
18、_ys TIMESTAMP NOT NULL, -预赛比赛时间BSSJ_js TIMESTAMP NOT NULL -决赛比赛时间)Gocreate table JUDGE /*-裁判-*/(CPBH VARCHAR(5) CONSTRAINT BSBH_PK PRIMARY KEY , -裁判编号CPXB VARCHAR(2) NOT NULL, CHECK(CPXB in(男,女), -裁判性别CPXM VARCHAR(20) NOT NULL, -裁判姓名CPDJ VARCHAR(10) NOT NULL CHECK (CPDJ IN (1,2,3 ) ) , -裁判等级ON DELET
19、E SET NULLON UPSET CASECADE )gocreate table houqinzu /*-后勤组-*/(ZBBH VARCHAR(5) CONSTRAINT ZBBH_PK PRIMARY KEY, -值班编号ZBRXM INT NOT NULL , -值班人姓名)go create table zhiban /*值班安排*/(ZBBH varchar(5) not null, -值班编号ZBSJ varchar(20) not null, -值班时间primary key(ZBBH,ZBSJ)gocreate table xuanchuan /*-宣传-*/(ZZXM
20、VARCHAR(20) , -作者姓名ZZYX VARCHAR(20) NOT NULL, -作者院系ZZXH VARCHAR(20) PRIMARY KEY -作者学号)gocreate table xueyuan /*-学院-*/(XYM VARCHAR(20) CONSTRAINT XYM_PK PRIMARY KEY,-学院名XYPM VARCHAR(20) NOT NULL -学院排名)gocreate table athleteCJ /*-运动员成绩-*/(YDY_bh VARCHAR(20) NOT NULL , -运动员编号YDY_bsbh VARCHAR(20) NOT NU
21、LL , -参加比赛编号YDY_bsmc VARCHAR(20) NOT NULL , -运动员参加比赛的项目名称YDY_yspl VARCHAR(5) NOT NULL, -运动员预赛排名YDY_jspl VARCHAR(5) NOT NULL, -运动员决赛排名PJL VARCHAR(2) NOT NULL CHECK(PJL in(是,否), -是否破纪录PRIMARY KEY (YDY_bsbh ,YDY_bh) - 主键声明)goCREATE TABLE JS /*预赛表*/(YDY_bh VARCHAR(20) NOT NULL , -运动员编号BSBH varchar(5) no
22、t null, -比赛编号Primary key(YDY_bh ,BSBH ) CREATE TABLE JS /*决赛表*/(YDY_bh VARCHAR(20) NOT NULL , -运动员编号BSBH varchar(5) not null, -比赛编号Primary key(YDY_bh ,BSBH ) CREATE TABLE ZHUCHI /*裁判主持比赛*/(CPBH VARCHAR(5) not null, - 裁判编号 BSBH varchar(5) not null, -比赛编号 primary key(CPBH,BSBH)) CREATE TABLE fuwu /*后勤
23、组服务*/(YDY_numVARCHAR(5) not null, ZBBH varchar(5) not null,Primary key(YDY_num,ZBBH)) 4.2数据安全性与完整性定义4.2.1创建相关的必要断言1.声明裁判等级低于3级的不能主持比赛的判罚CREATE ASSERTION CAIPAN CHECK(NOT EXISTS (SELECT CPXM FROM JUDGE WHERE CPDJ3 );4.2.2创建相关触发器1.该触发器的作用是阻挠修改运动员已确定的决赛成绩排名CREATE TRIGGER CJ_plTriggerAFTER UPDATE OF YDY_jspl ON athleteCJ REFERENCING OLD ROW AS OldTuple, NEW ROW AS NewTupleFOR EACH ROWWHEN (OldTuple.YDY_jsplNewTuple.YDY_jspl) UPDATE athleteCJ SET YDY_jspl = OldTuple.YDY_jspl WHERE YDY_jspl =NewTuple.YDY_jspl ;
限制150内