数据库课程设计——班级事务管理系统.doc
《数据库课程设计——班级事务管理系统.doc》由会员分享,可在线阅读,更多相关《数据库课程设计——班级事务管理系统.doc(33页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1.数据库设计内容1.1.课程设计任务与要求1.1。1.任务班级事务管理系统问题描述:班级管理信息系统的任务是收集、存储、管理班级同学的相关信息,以及班级日常管理中的相关信息。为班级信息公开、增进同学交流了解服务,同时加强班级管理、提高班级管理与服务的效率和质量。1。1。2。设计要求、实现用户登录.、实现管理员管理班级事务。(学生信息、成绩、课程、详细信息的增、删、改、查)、实现学生成绩查询。、实现个人事务管理。、实现生活委员班费管理。1。1。3。运行环境WindowsXP、SQL Server5。0、Myeclipse6。0、Tomcat5。5.28、IE 浏览器、JDK1.2需求分析1.2
2、。1.数据需求班级事务管理系统需要完成功能主要有:学生基本信息的输入,包括学号、姓名、担任职务等。学生基本信息的添加、查询、修改、删除,包括学生学号、姓名、职务、角色等。学生成绩的添加、查询、修改、删除,包括学号、课程号、分数。课程的添加、删除,包括课程号、课程名、学分、任课老师。生活委员对班费的管理,包括班费的收入、支出。个人对本人事务的管理,包括时间和事件.1.2.2事物需求管理员对学生事务管理部分,要求:a、可以查询学生基本、详细信息、课程信息以及成绩.b、可以对学生基本信息、详细信息进行添加、修改及删除操作。c、可以对课程信息进行添加、删除操作。d、可以对学生成绩进行添加、删除操作.生
3、活委员对班费的管理,要求:a、可以查询班费收入支出的详细信息。b、可以对班费信息进行添加、修改、删除操作.1.2.3关系模式学生用户表(学号、姓名、密码、担任职务、角色)课程表(课程号、课程名、学分、任课老师)成绩表(主键、学号、课程号、成绩)学生详细信息表(id、学生学号、出生日期、身份证号码、家庭往址、宿舍号、银行卡号)生活委员事物表(ID、时间、活动地点、活动人数、消费前班费余额、消费金额、消费后班费余额、活动意义、活动结果)其它管理页面(ID、时间、内容、结果)1.3概念结构设计1。3.1. E-R图担任职务密码学号角色姓名角色姓名ID密码ID成绩管理家庭住址出生日期学号ID身份证号银
4、行卡号学生详细信息查询管理学生基本信息管理员生活委员事务管理课程名课程管理管理角色密码姓名学生分数课程号学号结果事件时间查询总余额人数消费金额地点个人事务管理结果课程号时间ID意义ID任课老师学分1。4.逻辑结构设计1。4。1表结构1。4.2数据库设计及完整性约束学生用户表:create table user(id int auto_increment primary key,username varchar(10),userpass varchar(20),userjob varchar(10),userrole varchar(10)课程表:create table course(id i
5、nt auto_increment primary key,cname varchar(20),ccredit int,cteacher varchar(20)成绩表:create table Sc(id int auto_increment primary key,uid int,cid int,sgrade varchar(5)ALTER TABLE Sc ADD CONSTRAINT fk_Sc_uid FOREIGN KEY(uid) REFERENCES user(id);ALTER TABLE Sc ADD CONSTRAINT fk_Sc_cid FOREIGN KEY(cid)
6、 REFERENCES course(id);学生详细信息表:create table stuinfo(id int auto_increment primary key,stuid int,stubirth varchar(20),stuidentity varchar(30),stuaddr varchar(200),studorm varchar(20),stucard varchar(20)ALTER TABLE stuinfo ADD CONSTRAINT fk_stuinfo_stuid FOREIGN KEY(stuid) REFERENCES user(id);生活委员事物表:
7、create table shwy(id int auto_increment primary key,time varchar(20),addr varchar(100),stunum int ,startmoney decimal,expense decimal,endmoney decimal,actmeaning text,actresult varchar(10))其它管理页面:create table qita(id int auto_increment primary key,qtime varchar(20),qcontent text,qresult varchar(20)1
8、.4.3.数据库用户权限管理该系统设置三种类型的用户(1)管理员(admin) 即系统管理员拥有对学生基本信息、详细信息、成绩、课程的管理权限。(2)生活委员(shwy) 可以对班级班费收入支出的详细信息进行管理;(3)其他个人(qita)对个人事务事件进行管理。2。应用系统设计2.1。需求分析2.1。1数据需求班级事务管理系统需要完成功能主要有:学生基本信息的输入,包括学号、姓名、担任职务等。学生基本信息的添加、查询、修改、删除,包括学生学号、姓名、职务、角色等。学生成绩的添加、查询、修改、删除,包括学号、课程号、分数。课程的添加、删除,包括课程号、课程名、学分、任课老师.生活委员对班费的管
9、理,包括班费的收入、支出.个人对本人事务的管理,包括时间和事件。2。1。2事物需求管理员对学生事务管理部分,要求:a、可以查询学生基本、详细信息、课程信息以及成绩。b、可以对学生基本信息、详细信息进行添加、修改及删除操作。c、可以对课程信息进行添加、删除操作。d、可以对学生成绩进行添加、删除操作。生活委员对班费的管理,要求:a、可以查询班费收入支出的详细信息。b、可以对班费信息进行添加、修改、删除操作。2.1。3关系模式学生用户表(学号、姓名、密码、担任职务、角色)课程表(课程号、课程名、学分、任课老师)成绩表(主键、学号、课程号、成绩)学生详细信息表(id、学生学号、出生日期、身份证号码、家
10、庭往址、宿舍号、银行卡号)生活委员事物表(ID、时间、活动地点、活动人数、消费前班费余额、消费金额、消费后班费余额、活动意义、活动结果)其它管理页面(ID、时间、内容、结果)2。1.5数据字典 为了使各数据流,数据处理过程,存储过程不能反映其中的数据成,数据项目,数据特性,所以用数据字典来对数据流图中的各成份进行具体的定义,为系统的分析,设计及以后的实现提供供有关元素一致性定义和详细的描述:数据流字典数据流名称:管理员登录(P3) 来源:管理员去向:查询学生基本信息数据组成:姓名+密码+登录权限数据流名称:学生个人登录 来源:个人去向:查询个人信息数据组成:姓名+密码+登录权限数据流名称:生活
11、委员登录 来源:生活委员去向:班费管理数据组成:姓名+密码+登录权限数据流名称:所有学生基本信息查询 来源:管理员去向: 查询处理过程数据组成:学号姓名|密码担任职务角色数据流名称:所有学生详细信息查询 来源:管理员去向: 查询处理过程数据组成:学生学号出生日期身份证号码|家庭往址宿舍号|银行卡号数据流名称:成绩和课程查询来源:学生去向:查询处理过程数据组成:主键学号|课程号成绩数据流名称:班费管理查询来源:生活委员去向:查询处理过程(P3)数据组成:ID时间活动地点|活动人数消费前班费余额|消费金额消费后班费余额|活动意义|活动结果数据流名称:个人事务查询来源:学生去向:查询处理过程数据组成
12、:ID|时间内容|结果2。2。概念结构设计班费管理个人事务管理个人事务管理课程管理成绩管理详细信息管理基本信息管理生活委员管理班费事宜管理员管理班级事务班级事务管理系统2。3.详细设计2。3.1流程图更新页面删除删除添加页面查询基本信息添加页面详细信息查询管理员查询全部成绩登录添加页面添加页面删除普通用户添加页面删除个人事务管理页面事务登录界面班费管理页面添加页面删除更新页面成绩查询个人页面删除课程查询2。4。运行界面2.4。1管理员登陆界面2.4.2管理员查询、添加、修改、删除学生基本信息表程序代码说明package cn。com。dao;import java。io。Unsupported
13、EncodingException;import java。sql.Connection;import java。sql。PreparedStatement;import java.sql.ResultSet;import java.sql。SQLException;import java。util。LinkedList;import java.util.List;import cn。com.bean。UserBean;import cn。com.util。DBConnection;public class StudentDao public List queryAllStudent()Lis
14、t list = new LinkedList();Connection conn = DBConnection。getConnection();try PreparedStatement ps = conn.prepareStatement(”select * from user);ResultSet rs = ps.executeQuery();while (rs。next()) UserBean student = new UserBean();student.setId(rs。getInt(”id));student.setUsername(rs.getString(”username
15、));student。setUserpass(rs.getString(”userpass));student。setUserjob(rs。getString(”userjob”));student.setUserrole(rs。getString(userrole”);list。add(student); catch (SQLException e) e。printStackTrace();finallytry conn。close(); catch (SQLException e) e.printStackTrace();return list;public UserBean queryB
16、yId(int id)Connection conn = DBConnection。getConnection();UserBean student=null;try PreparedStatement ps = conn。prepareStatement(”select * from user where id=?”);ps.setInt(1, id);ResultSet rs = ps。executeQuery();while (rs.next() student = new UserBean();student。setId(rs。getInt(id));student。setUserna
17、me(rs。getString(”username);student。setUserpass(rs.getString(”userpass”);student.setUserjob(rs。getString(”userjob”);student。setUserrole(rs.getString(”userrole”); catch (SQLException e) e。printStackTrace();finallytry conn。close(); catch (SQLException e) e.printStackTrace();return student;public int up
18、dateStuInfo(UserBean stu)Connection conn = DBConnection。getConnection();UserBean student=null;int flag=0;try PreparedStatement ps = conn.prepareStatement(”update user set username=?,userpass=?,userjob=?,userrole=? where id=?);ps。setString(1,stu。getUsername() );ps。setString(2,stu。getUserpass() );ps。s
19、etString(3,stu。getUserjob();ps。setString(4,stu.getUserrole() );ps。setInt(5, stu。getId());flag= ps.executeUpdate(); catch (SQLException e) e.printStackTrace();finallytry conn。close(); catch (SQLException e) e.printStackTrace();return flag;public int deleteInfo(int id)Connection conn = DBConnection.ge
20、tConnection();UserBean lb=null;int flag=0;try PreparedStatement ps = conn。prepareStatement(”delete from user where id=?);ps.setInt(1, id);flag= ps。executeUpdate(); catch (SQLException e) e。printStackTrace();finallytry conn.close(); catch (SQLException e) e.printStackTrace();return flag;public int ad
21、dStudentInfo(UserBean ub) int flag = 0;Connection conn = DBConnection。getConnection();PreparedStatement ps;String username=ub。getUsername();try username=new String(username。getBytes(ISO-88591”),”UTF-8); catch (UnsupportedEncodingException e1) e1。printStackTrace();try ps = conn。prepareStatement(”inse
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 课程设计 班级 事务管理 系统
限制150内