托管培训中心信息管理系统课设报告_第1页
托管培训中心信息管理系统课设报告_第2页
托管培训中心信息管理系统课设报告_第3页
免费预览已结束,剩余8页可下载查看

下载本文档

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

文档简介

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

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

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

4、er字段名类型备注MnoVarchar管理员编号Mn ameVarchar管理员姓名MpasswordVarchar登陆密码2.学生表表名:Student字段名类型备注SnoVarchar学生编号Sn ameVarchar学生姓名SpasswordVarchar登陆密码3.教师表表名:Teacher字段名类型备注TnoVarchar教师编号Tn ameVarchar教师姓名TlevelVarchar教师等级TcharacterVarchar教师特点4.课程表表名:Course字段名类型备注CnoVarchar课程号Cn ameVarchar课程名TnoVarchar教师号Cn eed Stud

5、e ntInt招生人数Class TimeVarchar学时CcycleVarchar课程周期CaddrVarchar上课地点Camountint学费5.账目表表名:SC Amount字段名类型备注CnoVarchar课程号SnoVarchar学生号My AmountInt交费金额SC Amou nt TimeDate交费时间五实验设计1.概要结构设计2. 逻辑结构设计管理员表:Ma nager (Mno,M name,Mpassword) 3NF学生表:Student (Sno,Sname,Spassword) 3NF教师表:Teacher (Tno,Tname,Tlevel,Tcharac

6、ter) 3NF课程表:Course(Cno,C name,T no,C need_Stu,Cclass_time,Ccycle,Caddr,Camou nt) 3NFTno是参照Teacher表的外码账目表:SC_Amount (Cno,Sno,My_Amount,SC_Amount_Time) 3NFCno是参照Course表的外码Sno是参照Student表的外码3. 物理结构设计管理员表:CREATE TABLE Manager(Mno Varchar(5) primary key,Mn ame Varchar(20) not null,Mpassword Varchar(20) no

7、t null );学生表: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 Varchar(10), Tcharacter Varchar(100);课程表:CREATE TABLE Course (Cno Varchar(5) PR

8、IMARY 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_Amount (Cno Varchar(5), Sno Varchar(5),FOREIGN KEY(Cno) REFERENCES C

9、ourse(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号学生信息删除后,再有新学生来 注册时,系统分配给他的学生号就是0203号,而不是0205号,这样能填补之前删除的编号缺失,保证编号的连续性。分配学生号的代码如下:ResultSet

11、 rsno;String b;rsno=sql.executeQuery("SELECT Sno FROM Stude nt GROUP BY Sn o");rsnoast();n=rsno .getRow();rsno .beforeFirst();int k=0;b = new Stri ngn;while(rs no. next()bk=rs no .getStri ng(1);k+;int sno=0, i;for(i=0;i< n;i+)if(In teger.parseI nt(bi)!= 200+i+1)sn o=200+i+1;break;if(i=n

12、)sno=200+n+1;登陆和注册界面如下:2 .管理员界面登陆到管理员界面后,窗口标题为“欢迎你,管理员某某”。管理员界面是-个选项卡窗格,分“添加” “删除”“查询” “更新”四个选项卡,每个选项卡上有 不同的图片背景和对应功能的按钮,点击按钮时会弹出不同的功能窗口,完成各种 管理活动,主界面如下:添加时,要求输入该实体的主码作为索引,弹出一个只有一行空白区表格的窗 口,输入要添加的信息后,点击“确定”按钮,即可提交,领取相应的编号,若失 败,弹出对话框提示添加失败;删除时,要求输入该实体的主码作为索引,点击“确定”按钮,在下方显示要 删除的信息,再点击“删除”按钮,即可删除;若该实体不

13、存在,则弹出对话框提 示;查询时,弹出带有表格的窗体,显示要查询的相应信息;更新时,要求输入该实体的主码作为索引,点击“确定”按钮,在下方显示要 修改的信息,再点击“修改”按钮,即可修改;修改成功弹出对话框提示,修改失 败弹出对话框提示;若该实体不存在,弹出对话框提示;由于添加、删除、修改窗体皆是通过表格组件实现的,所以界面在此处不一一 举例,尽给出添加课程和查询欠费学生信息的界面:欠费学生名单二I回区学主导学生姓名0301奥数0201赵伟0302口才0205姚害全0306吉他0202张力虹0305吉他02110309口牙02Q1赵伟0310英语0202张力虹0314围棋0206上关羌云3.学

14、生界面当软件检测到用户名为学生编号时,则自动进入学生登陆界面,窗口标题为“欢 迎你,某某同学”。当该生有未交费或费用已到期的情况时,将弹出对话框提示,该 功能是通过存储过程实现的:create or replace procedure Warni ng(PC no in Varchar2,PSno in Varchar2, time out nu mber)asPMyAmou nt int;PSCamou nt_Time Date;BEGINSelect MyAmou nt,SCamou nt_Timeinto PMyAmou nt,PSCamou nt_TimeFrom SC_Amou nt

15、Where Cn o=PC no and Sno=PS no;if PSCamou nt_Time IS null the ntime:=30;elseselecttrun c(sysdate)-tru nc(PSCam oun t_Time)in to timefrom dual;end if;commit;end;该存储过程传入两个参数,课程号和学生号,返回一个参数,距上次交费的课程 开始日期的天数,如果这个天数大于 28 (一般托管中心都是四周为一个月的课程) 则提示“请及时交费”,存储过程调用代码如下:CallableStateme nt proc = n ull; for(i nt

16、i=0;i< n;i+)proc = con .prepareCall("call Warni ng(?,?,?)");proc.setString(1, bi);proc.setStri ng(2, sno);proc.registerOutParameter(3, TypesN TEGER); proc.execute();int ok = proc.get In t(3);if(ok>28)rs=sql.executeQuery("SELECTCn ame FROM Course WhereCno='"+bi+"”&#

17、39;);rs. next();JOptio nPan e.showMessageDialog(butto n1,"请及时交费:"+rs.getString(1)+"课(课程号为"+bi+")","交费通知",JOptio nPan e.WARNING_MESSAGE);学生登陆界面有两个菜单,分别是“查询”和“管理”,管理则有一个菜单项,“注 销课程”,窗口中间有两个按钮,分别为“选择课程”和“自助交费”,点击“选择课程”,将弹出选课界面,学生主界面如下图: 它要与数据库动态连接,前面的 JCheckBox是通过

18、查询得到的,而后面的 JComboBo)是 根据前面的JCheckBox的值查询课程表得到的,所以过程有些复杂,一方面想要代码简 单,另一方面又要考虑数据库在同一时刻有允许的最大连接数目,而通过实践发现同时 对两个ResultSet进行操作就会出错,所以最终只能将查询到的科目存在数组中,再供 它用。选课界面: 在制作这个界面时,我真是下了不少的功夫,因为我所采用的是盒式布局,科目是可以添加的,所以在查询科目个数之前无法确定盒 子的个数,好在java能够用变量定义数组,于是我创建了一个盒子数组,终于实现如图 效果。可随之而来又产生了一个问题,随着科目的增加,窗体大小不够显示所有组件了, 所以我又

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

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

温馨提示

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

评论

0/150

提交评论