资料内容仅供您学习参考,如有不当或者侵权,请联系改正或者删除。
一.实验题目:托管培训中心信息管理系统二.实验目的《数据库与信息管理课程设计》是软件工程专业集中实践性环节之一, 是计算机学科基础的一门重要的实践教学课程, 是学习完《数据库概论》课程后进行的一次全面的综合练习。
其目的在于加深对数据库基础理论和基本知识的理解, 掌握使用数据库进行软件设计的基本方法, 提高运用数据库解决实际问题的能力, 最终实现对于给定的应用要求, 构造最优的数据库模式, 建立数据库及其应用系统, 使之能够有效地存储数据, 满足各种用户的应用需求(信息要求和处理要求)。
三.实验要求1.处理学生报名根据学生报名的科目查询科目信息, 如果该科目已经满员, 则提醒学员, 如果该科目没有满员, 则让用户选择相应的教师, 并报名登记, 交纳学费。
2.维护科目开设不同的科目, 同一门课程根据教师的知名度, 向学生收取不同的费用。
3.安排教室及上课日程根据教师及学生信息确定某个科目的上课地点及时间并形成学生的课表。
4.管理帐目收取学费并入帐, 催交费用等。
四.需求分析托管培训中心信息管理系统, 有两类用户:一是培训中心的管理者, 可添加、删除、修改、查询学生信息、课程信息、账目信息等, 是托管中心信息管理系统的最高权力者。
添加、删除、修改时, 若遇到类型不匹配或破坏了数据库完整性, 应弹出相应的提示对话框, 查询时, 应尽量使信息一目了然;另一个用户则是学生用户, 学生可查询课程信息、教师信息、个人课表和个人账目信息, 可选课并自助交费。
选课时, 让学生选择课程和教师, 若该课程人数已满, 则提示报名人数已满, 若该生已经选择该课程, 也提示您已经选择了该课程, 力争使软件的操作性友好。
为了便于管理, 管理员编号为以” 00”开头的四位数字, 教师编号为以” 01”开头的四位数字, 学生编号为以” 02”开头的四位数字, 这样在登陆时, 系统就能够经过判断编号类型, 调用不用的界面。
当有学生注册或添加教师或课程时, 系统将自动生成学生号、教师号、课程号, 为了防止删除时产生编号的缺失, 系统在分配编号时将分配给新数据当前未使用的最小编号, 填补之前删除的数据的空白这样就能保证编号的连续性。
数据字典:资料内容仅供您学习参考,如有不当或者侵权,请联系改正或者删除。
1. 管理员表表名:Manager2. 学生表表名:Student3. 教师表表名:Teacher4. 课程表表名:Course5. 账目表表名:SC_Amount五.实验设计1.概要结构设计资料内容仅供您学习参考,如有不当或者侵权,请联系改正或者删除。
学生2.逻辑结构设计管理员表:Manager (Mno,Mname,Mpassword) 3NF 学生表:Student(Sno i Sname,Spassword) 3NF 教师表:Teacher(TnoJ^ameJIevehTcharacter) 3NF 课程表:(Cno,C name,T no,C need_Stu,Cclass_time,Ccycle,Caddr,Cam ount) 3NFCourse Tno 是参照Teacher表的外码账目表:SC_Amount (Cno,Sno,My Amount,SC_Amount_Time) 3NFSno 是参照Student 表的外码3.物理结构设计Cno 是参照Course表的外码资料内容仅供您学习参考,如有不当或者侵权,请联系改正或者删除。
管理员表:CREATE TABLE Manager(Mno Varchar(5) primary key,Mname Varchar(20) not null,Mpassword Varchar(20) not 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) 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_Amount(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登陆界面,设计简单,一目了然,要求用户输入用户名和密码, 界面下方有两个按钮, 分别是”登陆”和”注册”。
输入用户名和密码后, 点击”登陆”按钮时, 判断用户名是否存在, 若不存在, 则弹出提示对话框; 若存在, 则判断密码是否相符; 若相符, 进入相应的界面; 若不相符, 弹出对话框提示密码错误。
点击”注册”按钮时, 弹出注册界面, 要求输入姓名和密码, 并要求确认密码; 当有未输入项时, 弹出对话框提示输入; 若两次输入的密码不一致, 弹出对话框提示重新输入; 提交成功后, 弹出对话框告知学生号。
学生注册时, 系统将自动生成学生号, 为了防止删除时产生编号的缺失, 不便于管理, 系统在分配编号时, 将分配给新数据当前未使用的最小编号, 如: 原有0201,0202,0203,0204 四个学生, 管理员将0203 号学生信息删除后, 再有新学生来注册时, 系统分配给她的学生号就是0203 号, 而不是0205号, 这样能填补之前删除的编号缺失, 保证编号的连续性。
分配学生号的代码如下:ResultSet rsno;String b[];rsno=sql.executeQuery("SELECT Sno FROM Student GROUP BY Sno");st();n=rsno.getRow();rsno.beforeFirst();int k=0;b = new String[n];while(rsno.next()){b[k]=rsno.getString(1);k++;}int sno=0, i;for(i=0;i<n;i++){if(Integer.parseInt(b[i])!= 200+i+1){sno=200+i+1;break;资料内容仅供您学习参考,如有不当或者侵权,请联系改正或者删除。
}}if (i=二n )sno=200+n+1;登陆到管理员界面后,窗口标题为”欢迎你,管理员某某”。
管 理员界面是一个选项卡窗格,分”添加” ”删除” ”查询” ”更新”四个选项卡,每个选项卡上有不同的图片背景和对应功能的按钮,点 击按钮时会弹出不同的功能窗口,完成各种管理活动,主界面如登陆和注册界面如下2.管理员界面下:添加时,要求输入该实体的主码作为索引,弹出一个只有一行空白区表格的窗口,输入要添加的信息后,点击”确定”按钮,即可提交,领取相应的编号,若失败,弹出对话框提示添加失败;删除时,要求输入该实体的主码作为索引,点击”确定”按钮,在下方显示要删除的信息,再点击”删除”按钮,即可删除;若该实体不存在,则弹出对话框提示;查询时,弹出带有表格的窗体,显示要查询的相应信息;更新时,要求输入该实体的主码作为索引,点击”确定”按钮,在下方显示要修改的信息,再点击”修改”按钮,即可修改;修改成功弹出对话框提示,修改失败弹出对话框提示;若该实体不存在,弹出对话框提示;由于添加、删除、修改窗体皆是经过表格组件实现的,因此界面在此处不一一举例,尽给出添加课程和查询欠费学生信息的界面:资料内容仅供您学习参考,如有不当或者侵权,请联系改正或者删除。
3.学生界面当软件检测到用户名为学生编号时,则自动进入学生登陆界面窗口标题为”欢迎你,某某同学”。
当该生有未交费或费用已到期的情况时,将弹出对话框提示,该功能是经过存储过程实现的:create or replace procedure Warni ng(PC no in Varchar2,PSn o in Varchar2,time out nu mber)asPMyAmou nt int;PSCam oun t_Time Date;BEGINSelect MyAm oun t,SCam oun t_Timeinto PMyAmou nt,PSCamou nt_TimeFrom SC_AmountWhere Cno 二PC no and Sn o=PS no;if PSCamou nt_Time IS null the ntime:=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.prepareCall("{call Warning(?,?,?)}");proc.setString(1, b[i]);proc.setString(2, sno);proc.registerOutParameter(3, Types.INTEGER);proc.execute();int ok = proc.getInt(3);if(ok>28){rs二sql.executeQuery("SELECT Cname FROMCourse Where资料内容仅供您学习参考,如有不当或者侵权,请联系改正或者删除。