托管培训中心信息管理系统课设报告_第1页
托管培训中心信息管理系统课设报告_第2页
托管培训中心信息管理系统课设报告_第3页
托管培训中心信息管理系统课设报告_第4页
托管培训中心信息管理系统课设报告_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、文档来源为:从网络收集整理.word版本可编辑.欢迎下载支持一.实验题目:托管培训中心信息管理系统二.实验目的数据库与信息管理课程设计是软件工程专业集中实践性环节之一,是计算机 学科基础的一门重要的实践教学课程,是学习完数据库概论课程后进行的一次全 面的综合练习。其目的在于加深对数据库基础理论和基本知识的理解,掌握使用数据 库进行软件设计的基本方法,提高运用数据库解决实际问题的能力,最终实现对于给 定的应用要求,构造最优的数据库模式,建立数据库及其应用系统,使之能够有效地 存储数据,满足各种用户的应用需求(信息要求和处理要求)。三.实验要求1 .处理学生报名根据学生报名的科目查询科目信息,如果

2、该科目已经满员,则提醒学员,如 果该科目没有满员,则让用户选择相应的教师,并报名登记,交纳学费。2 .维护科目开设不同的科目,同一门课程根据教师的知名度,向学生收取不同的费用。3 .安排教室及上课日程根据教师及学生信息确定某个科目的上课地点及时间,并形成学生的课表。4 .管理帐目收取学费并入帐,催交费用等。四.需求分析托管培训中心信息管理系统,有两类用户:一是培训中心的管理者,可添加、删除、修改、查询学生信息、课程信息、账目 信息等,是托管中心信息管理系统的最高权力者。添加、删除、修改时,若遇到类型 不匹配或破坏了数据库完整性,应弹出相应的提示对话框,查询时,应尽量使信息一 目了然;另一个用户

3、则是学生用户,学生可查询课程信息、教师信息、个人课表和个人账 目信息,可选课并自助交费。选课时,让学生选择课程和教师,若该课程人数已满, 则提示报名人数已满,若该生已经选择该课程,也提示您已经选择了该课程,力争使 软件的操作性友好。为了便于管理,管理员编号为以“ 00”开头的四位数字,教师编号为以“ 01”开 头的四位数字,学生编号为以“ 02”开头的四位数字,这样在登陆时,系统就可以通 过判断编号类型,调用不用的界面。当有学生注册或添加教师或课程时,系统将自动生成学生号、教师号、课程号, 为了防止删除时产生编号的缺失,系统在分配编号时,将分配给新数据当前未使用的 最小编号,填补之前删除的数据

4、的空白,这样就能保证编号的连续性。数据字典:1 .管理员表表名:Manager字段名备注MnoVarchar管理员编号MnameVarchar管理员姓名MpasswordVarchar登陆密码2.学生表表名:Student字段名|备注SnoVarchar学生编号SnameVarchar学生姓名SpasswordVarchar登陆密码3.教师表表名:Teacher字段名备注TnoVarchar教师编号TnameVarchar教师姓名TlevelVarchar教师等级TcharacterVarchar教师特点4.课程表表名:Course字段名个备注CnoVarchar课程号 CnameVarcha

5、r课程名TnoVarchar教师号Cneed_StudentInt招生人数1Class_TimeVarchar学时CcycleVarchar课程周期CaddrVarchar上课地点Camountint学费5.账目表表名:SC_Amount字段名备注CnoVarchar课程号SnoVarchar学生号My AmountInt交费金额SC_Amount_TimeDate父费时间五.实验设计1 .概要结构设计学生2 .逻辑结构设计管理员表:Manager (Mno,Mname,Mpassword) 3NF学生表:Student (Sno,Sname,Spassword) 3NF教师表:Teacher

6、 (Tno,Tname,Tlevel,Tcharacter) 3NF课程表:Course (Cno,Cname,Tno,Cneed_Stu,Cclass_time,Ccycle,Caddr,Camount) 3NFTno是参照Teacher表的外码账目表:SC_Amount (Cno,Sno,My_Amount,SC_Amount_Time) 3NFCno是参照Course表的外码Sno是参照Student表的外码3 .物理结构设计管理员表:CREATE TABLE Manager(Mno Varchar(5) primary key, Mname Varchar(20) not null,

7、Mpassword Varchar(20) not null3文档来源为:从网络收集整理.word版本可编辑.文档来源为:从网络收集整理.word 版本可编辑.欢迎下载支持);学生表:CREATE TABLE Student(Sno Varchar(5) primary key,Sname Varchar(20) not null,Spassword Varchar(20) not null);教师表:CREATE TABLE Teacher(Tno Varchar(5) primary key not null,Tname Varchar(20) not null,Tlevel Varcha

8、r(10),Tcharacter Varchar(100);课程表:CREATE TABLE Course(Cno Varchar(5) PRIMARY KEY not null,Cname Varchar(20) not null,Tno Varchar(5),Cneed_Stu int,Cclass_time Varchar(10),Ccycle Varchar(10),Caddr Varchar(20),Camount int,FOREIGN KEY(Tno) REFERENCES Teacher(Tno)ON DELETE CASCADE);账目表:CREATE TABLE SC_Am

9、ount(Cno Varchar(5),Sno Varchar(5),FOREIGN KEY(Cno) REFERENCES Course(Cno)ON DELETE CASCADE,FOREIGN KEY(Sno) REFERENCES Student(Sno)ON DELETE CASCADE,PRIMARY KEY(Cno,Sno),MyAmount int,SCamount_time DATE);六软件设计与实现1 .登陆与注册界面登陆界面仿照QQ登陆界面,设计简单,一目了然,要求用户输入用户名和密码,界面下方有两个按钮,分别是“登陆”和“注册”。输入用户名和密码后,点击 “登陆” 按

10、钮时, 判断用户名是否存在,若不存在,则弹出提示对话框;若存在,则判断密码是否相符;若相符,进入相应的界面;若不相符,弹出对话框提示密码错误。点击 “注册” 按钮时, 弹出注册界面,要求输入姓名和密码,并要求确认密码;当有未输入项时,弹出对话框提示输入;若两次输入的密码不一致,弹出对话框提示重新输入;提交成功后,弹出对话框告知学生号。学生注册时,系统将自动生成学生号,为了防止删除时产生编号的缺失,不便于管理,系统在分配编号时,将分配给新数据当前未使用的最小编号,如:原有0201,0202,0203,0204 四个学生,管理员将0203号学生信息删除后,再有新学生来注册时,系统分配给他的学生号就

11、是0203 号,而不是0205 号,这样能填补之前删除的编号缺失,保证编号的连续性。分配学生号的代码如下:ResultSet rsno;String b;rsno=sql.executeQuery("SELECT Sno FROM Student GROUP BY Sno");rsno.last();n=rsno.getRow();rsno.beforeFirst();int k=0;b = new Stringn;while(rsno.next()bk=rsno.getString(1);k+;int sno=0, i;for(i=0;i<n;i+)if(Integ

12、er.parseInt(bi)!= 200+i+1)sno=200+i+1;break;if(i=n)sno=200+n+1;登陆和注册界面如下:5文档来源为:从网络收集整理.word 版本可编辑.文档来源为:从网络收集整理.word版本可编辑.欢迎下载支持2 .管理员界面登陆到管理员界面后,窗口标题为“欢迎你,管理员某某”。管理员界面是一个选项卡窗格,分“添加”“删除”“查询”“更新”四个选项卡,每个选项卡上有不同的图片背景和对应功能的按钮,点击按钮时会弹出不同的功能窗口,完成各种 管理活动,主界面如下:添加时,要求输入该实体的主码作为索引,弹出一个只有一行空白区表格的窗 口,输入要添加的信

13、息后,点击“确定”按钮,即可提交,领取相应的编号,若失 败,弹出对话框提示添加失败;删除时,要求输入该实体的主码作为索引,点击“确定”按钮,在下方显示要 删除的信息,再点击“删除”按钮,即可删除;若该实体不存在,则弹出对话框提 示;查询时,弹出带有表格的窗体,显示要查询的相应信息;更新时,要求输入该实体的主码作为索引,点击“确定”按钮,在下方显示要 修改的信息,再点击“修改”按钮,即可修改;修改成功弹出对话框提示,修改失 败弹出对话框提示;若该实体不存在,弹出对话框提示;由于添加、删除、修改窗体皆是通过表格组件实现的,所以界面在此处不一一 举例,尽给出添加课程和查询欠费学生信息的界面:3 .学

14、生界面当软件检测到用户名为学生编号时,则自动进入学生登陆界面,窗口标题为“欢 迎你,某某同学”。当该生有未交费或费用已到期的情况时,将弹出对话框提示,该 功能是通过存储过程实现的:create or replace procedure Warning(PCno in Varchar2,PSno in Varchar2, time out number) asPMyAmount int;PSCamount_Time Date;BEGINSelect MyAmount,SCamount_Timeinto PMyAmount,PSCamount_TimeFrom SC_AmountWhere Cno

15、=PCno and Sno=PSno;if PSCamount_Time IS null thentime:=30;elseselecttrunc(sysdate)-trunc(PSCamount_Time)into timefrom dual;end if;commit;end;该存储过程传入两个参数,课程号和学生号,返回一个参数,距上次交费的课程开始日期的天数,如果这个天数大于28 (一般托管中心都是四周为一个月的课程),则提示“请及时交费”,存储过程调用代码如下: CallableStatement proc = null;for(int i=0;i<n;i+)proc = con

16、.prepareCall("call Warning(?,?,?)");proc.setString(1, bi);proc.setString(2, sno);proc.registerOutParameter(3, Types.INTEGER);proc.execute();int ok = proc.getInt(3);if(ok>28)rs=sql.executeQuery("SELECT Cname FROM Course Where Cno='"+bi+"'"); rs.next();JOptionP

17、ane.showMessageDialog(button1,请及时交费:"+rs.getString(1)+”课 (课程号为"+bi+")","交费通知",JOptionPane.WARNING_MESSAGE);学生登陆界面有两个菜单,分别是“查询”和“管 理”,管理则有一个菜单项,“注销课程”,窗口中间有 两个按钮,分别为“选择课程”和“自助交费”,点击 “选择课程”,将弹出选课界面,学生主界面如下图: 选课界面:在制作这个界面时,我真是下了不少的功夫,因为 它要与数据库动态连接,前面的 JCheckBox是通过查 询得到的,而后

18、面的JComboBox是根据前面的 JCheckBox的值查询课程表得到的,所以过程有些复 杂,一方面想要代码简单,另一方面又要考虑数据库 在同一时刻有允许的最大连接数目,而通过实践发现 同时对两个ResultSet进行操作就会出错,所以最终只 能将查询到的科目存在数组中,再供它用。我所采用的是盒式布局,科目是可以添加的,所:从网络收集整理.word版本可编辑.文档来源为:从网络收集整理.word 版本可编辑.欢迎下载支持.以在查询科目个数之前无法确定盒子的个数,好在 java 能够用变量定义数组,于是我创建了一个盒子数组,终于实现如图效果。可随之而来又产生了一个问题,随着科目的增加,窗体大小

19、不够显示所有组件了,所以我又想到可以将这些盒子添加到一个滚动面板里,最后终于得到我想要的效果了。还有一个小插曲,就是由于我添加了背景图片,没加入滚动面板时,图片能够显示,加入滚动面板后,图片就怎么都不显示了,即使我将滚动面板pane 设为透明:pane.setOpaque(false);图片依然无法正确显示,后来通过上网查找解决方法,了解到要想让滚动面板透明,光设置面板透明是不够的,同时还要要设pane.getViewport().setOpaque(false);滚动条也要设置成透明:pane.getVerticalScrollBar().setOpaque(false);最终得到理想的效果

20、。部分代码如下:JCheckBox chbox;JComboBox cbox;/查询Cname并将科目名存入JCheckBox类型的chbox数组的代码略/通过JCheckBox类型的chbox数组中的Cname值获得相应的教师信息,并存入 JComboBox类型的cbox数组中,代码如下:ResultSet rs2;String str;for(j=0;j<n;j+)rs2=sql.executeQuery("SELECT Tno FROM Course WHERE Cname = ' " + chboxj.getText() + " ' ORDER BY Tno");rs2.last();m=rs2.getRow();rs2.beforeFirst();st

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论