收藏 分享(赏)

学生信息管理系统课程设计报告83433.doc

上传人:精品资料 文档编号:10793043 上传时间:2020-01-09 格式:DOC 页数:34 大小:279.50KB
下载 相关 举报
学生信息管理系统课程设计报告83433.doc_第1页
第1页 / 共34页
学生信息管理系统课程设计报告83433.doc_第2页
第2页 / 共34页
学生信息管理系统课程设计报告83433.doc_第3页
第3页 / 共34页
学生信息管理系统课程设计报告83433.doc_第4页
第4页 / 共34页
学生信息管理系统课程设计报告83433.doc_第5页
第5页 / 共34页
点击查看更多>>
资源描述

1、课设名称: 学生信息管理系统 院 (系): 信息科学与工程学院 姓 名: 蒋登丽 学 号: 201410411406 年 级: 2014 级 专业班级: 计算机科学与技术 4班 指导教师: 黄荣兵 时 间: 2016 年 11月 目录第 一 部 分 摘 要 2第 二 部 分 目 的 背 景 与 意 义 4第 三 部 分 需 求 分 析 .4第 四 部 分 系 统 设 计 .44.1 结 构 设 计 44.2 功 能 结 构 图 .54.3 功 能 流 程 以 及 工 作 流 描 述 6第 五 部 分 数 据 库 的 设 计 65.1 数 据 库 设 计 65.2 数 据 表 的 设 计 7第

2、六 部 分 详 细 设 计 .76.1 学 生 管 理 系 统 主 界 面 模 块 76.2 学 生 信 息 管 理 模 块 86.3 课 程 信 息 管 理 模 块 .106.4 查 询 模 块 11图 6.5 数 据 库 操 作 模 块 11第 七 部 分 课 程 设 计 心 得 11第一部分 摘 要该项目开发的软件为学校学生信息管理系统软件,是鉴于目前学校学生人数剧增,学生信息呈爆炸性增长的前提下,学校对学生信息管理的自动化与准确化的要求日益强烈的背景下构思出来的,该软件设计完成后可用于所有教育单位(包括学校,学院等等)的学生信息的管理。目前社会上信息管理系统发展飞快,各个企事业单位都引

3、入了信息管理软件来管理自己日益增长的各种信息,学生管理系统也是有了很大的发展,商业化的学生信息管理软件也不少,但本系统完全独立开发,力求使系统功能简洁明了,但功能齐全且易于操作。学生信息管理系统是一个教育单位不可缺少的部分,它的内容对于学校的决策者和管理者来说都至关重要。本文介绍了学生信息管理系统的开发整个过程,阐述了系统分析、系统设计、数据库设计和系统实施的全过程。在开发方法上本系统利用了软件工程化的思想和方法,总体上采用结构化生命周期开发方法,具体模块实施采用了原型法和面向对象系统开发方法。并采用 JAVA 作为开发工具,mysql 作为后台数据库。本系统具有学生管理、课程管理、成绩管理、

4、信息查询等功能,分成四大模块,每个模块都相互联系,但不相互干扰,这符合了软件模块开发的思想。本系统完成了学生信息的增加、修改、删除、查询和选课,课程信息的增加、修改、删除、查询,成绩的添加、修改、查询等功能。【关键字】:信息管理系统、模块设计、软件工程。第二部分 目的背景与意义学生信息管理系统是一个教育单位不可缺少的部分。一个功能齐全、简单易用的信息管理系统不但能有效地减轻学校相关工作人员的工作负担,它的内容对于学校的决策者和管理者来说都至关重要,所以学生信息管理系统应该能够为用户提供充足的信息和快捷的查询手段。但一直以来人们使用传统人工的方式管理文件档案、统计和查询数据,这种管理方式存在着许

5、多缺点,如:效率低、保密性差,人工的大量浪费;另外时间一长,将产生大量的文件和数据,这对于查找、更新和维护都带来了不少困难。随着科学技术的不断提高,计算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着来越重要的作用。作为计算机应用的一部分,使用计算机对学校的各类信息进行管理,具有手工管理所无法比拟的优点.例如:检索迅速、查询方便、效率高、可靠性好、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高学校信息管理的效率,也是一个单位科学化、正规化管理,与世界接轨的重要条件。第三部分 需求分析学生信息管理系统的功能总结起来,共需要以下几个方面:1. 学生信息

6、管理管理所有学生的基本信息,包括增加、修改、删除等,也可以根据各种条件查询出需要的信息。2. 课程信息管理管理所有课程的基本信息,包括增加、修改、删除等,也可以根据各种条件查询出需要的信息。3. 选课与成绩管理根据学号进行选课,登记课程的成绩,可以根据学号查询出来选课信息与成绩。第四部分 系统设计4.1 结构设计根据对系统的需求分析,本系统将分为 4 个模块: 学生管理:管理学生的基本信息,包括个人信息的添加、修改、删除,以及选课信息的添加。 课程管理:管理课程的基本信息,包括课程信息的添加、修改和删除。 成绩管理:管理学生的选课的成绩信息,包括成绩的登记与修改。 信息查询:查询已经登记的信息

7、,包括学生的基本信息、课程的基本信息与成绩信息。4.2 功能结构图系统的功能结构如图 1 所示。学生管理系统学生管理课程管理成绩管理信息查询增加修改删除学生选课增加修改删除增加修改学生查询课程查询成绩查询按学号查询按姓名查询按专业查询按性别查询按学院查询按课程名称查询按授课教师查询查询所有成绩按学分绩点查询按单科成绩查询图 1 学生管理系统功能结构图4.3 功能流程以及工作流描述1. 增加学生信息系统操作人员打开学生信息添加界面,输入相关的信息(姓名、性别、民族、籍贯、出生日期、入学年份、专业和学院等) ,在数据库中添加相关数据。2. 修改学生信息根据学生的学号查询出该学生的相关信息,修改相关

8、条目后保存在数据库中。3. 删除学生信息根据学生的学号查询出该学生的相关信息,确定删除后,在数据库中删除该信息。4. 学生选课选择学生学号与需要选择的课程,确定无误后保存,数据库中将自动添加新的选课记录。5. 增加课程信息系统操作人员根据打开的课程增加界面,输入相关信息(课程名称、授课教师、课程学分、课程系数、上课地点等) ,在数据库中添加相关的数据。6. 修改课程信息根据课程号查询出该课程的相关信息,修改条目后保存在数据库中。7. 删除课程信息根据课程号查询出该课程的相关信息,确认删除后,在数据库中删除该信息。8. 登记成绩根据学号,以及该学生所选择的课程,进行成绩登记,为选课的同学将无法登

9、记。9. 修改成绩对已经登记的成绩信息进行修改。10. 学生查询可以根据学生学号、学生姓名、学生性别、学生所学专业、学生所属学院来对学生信息进行查询,所有符合查询条件的学生信息将都被显示出来。11. 课程查询按照课程名称和授课教师的名称对课程详细信息进行查询,所有符合查询条件的课程信息都将会被显示出来。12. 成绩查询:根据学生的学号来查询该学生所有课程的成绩。第五部分 数据库的设计5.1 数 据 库 设 计此系统使用的是 mysql 数据库,由于此系统需要的数据量不是很大,所以选择比较简便的 mysql 数据库。此系统的数据库名称是 studentsys,创建语句如下:5.2 数 据 表 的

10、 设 计数据库中包含三个表,即是学生信息表(student) 、课程信息表(Course)和学生选课表(SC ) ,设计要求如表 13 所示。表 1 学生信息表(Student)名称 字段名称 数据类型 主键 非空学号 Snum Varchar(20) Yes Yes学生姓名 Sname Varchar(10) No No性别 Ssex Varchar(2) No No民族 Sethnic Varchar(4) No No籍贯 Shome Varchar(20) No No入学年份 Syear Varchar(10) No No专业 Smajor Varchar(10) No No学院 Sco

11、llege Varchar(10) No No出生日期 Sbirth Varchar(10) No No学分绩点 Spoint Varchar(10) No No表 2 课程信息表(Course)名称 字段名称 数据类型 主键 非空课程编码 Cnum Varchar(10) Yes Yes课程名称 Cname Varchar(20) No No授课教师 Cteacher Varchar(10) No No上课地点 Cplace Varchar(10) No No课程学分 Cpoint Smallint No No课程系数 Cratio Varchar(2,2) No No表 3 学生选课表(S

12、C)名称 字段名称 数据类型 主键 非空学号 Snum Varchar(20) Yes Yes课程编码 Cnum Varchar(10) Yes Yes成绩 Grade Float(4,2) No No第六部分 详细设计该系统由 6 个模块构成,包括学生管理系统主界面模块、学生信息管理模块、课程信息管理模块、成绩管理模块、信息查询模块和数据库操作模块,以下分别加以叙述:6.1 学 生 管 理 系 统 主 界 面 模 块学生管理系统的主界面模块包括 StuMS.java 和 StuMain.java 两个文件。StuMS 是学生管理系统的主运行类,其中有整个程序的主方法 main,该文件生成了

13、StuMain 类的一个实例,从而生成了学生管理系统的主界面,如图 2 所示。StuMain 类继承了 JFrame 类,实现了事件监听接口,它有一个不带参数的构造函数 StuMain(),用来生成 StuMain 实例,StuMain 类将所有的功能集中到面板中,面板上的按键是按网格排布,生成按钮,通过按钮的响应函数调用其他模块的函数来实现学生管理系统的各个功能,以下是主界面的运行程序:图 6.1.1 主界面运行程序6.2 学 生 信 息 管 理 模 块学生信息管理模块主要由StuInfo.java、AddStuInfo.java 、EditStuInfo.java 、DelStuInfo.

14、java、SelectCourse.java 和StuInfoSearchSnum.java 这六个文件组成,每个 java 文件只有一个类,完全实现模块化设计,StuInfo 类是 AddStuInfo、EditStuInfo、DelStuInfo 的超类,因为这三个类生成的界面是相同的具有共同之处。SelectCourse 模块是选课模块,StuInfoSearchSnum 是查询模块,用于AddStuInfo、EditStuInfo、DelStuInfo 调用来查询学生信息以便增加、修改和删除学生信息。学生信息管理模块的几个界面如下:图 6.2.1 学生信息添加界面图 6.2.2 学生信

15、息修改界面图 6.2.3 学生信息删除界面图 6.2.3 学生选课界面6.3 课 程 信 息 管 理 模 块课程信息管理模块主要由CourseInfo.java、AddCourseInfo.java、EditCourseInfo.java、DelCourseInfo.java 和StuInfoSearchSnum.java 这六个文件组成,每个 java 文件只有一个类,完全实现模块化设计,CourseInfo 类是 AddCourseInfo、EditCourseInfo、DelCourseInfo 的超类,因为这三个类生成的界面是相同的具有共同之处。CourseInfoSearchSnum

16、 是查询模块,用于AddCourseInfo、EditCourseInfo、DelCourseInfo 调用来查询课程以便增加、修改和删除课程。课程信息管理模块的几个界面如下:图 6.3.1 课程信息增加界面图 6.3.1 课程信息修改界面图 6.3.1 课程信息删除界面6.4 查 询 模 块查 询 模 块 分 学 生 信 息 查 询 、 课 程 信 息 查 询 和 成 绩 查 询 :界 面 如 下 :图 6.4 查询模块图 6.5 数 据 库 操 作 模 块数据库操作模块包括连接数据库和数据库操作,连接数据库在类 DataBase.java 中,操作数据库类分别在几个不同的类里,学生信息操作

17、在 StuBean.java,选课操作在 Csbean.java 中,课程操作在 CrsBean.java 中,代码在附录里,这里就不重复了。第 七 部 分 课 程 设 计 心 得在 本 系 统 的 开 发 过 程 中 , 由 于 本 人 是 初 次 开 发 软 件 , 在 知 识 、 经 验 方 面 都 存 在着 不 足 。 另 外 , 在 整 个 开 发 的 过 程 中 , 时 间 也 比 较 仓 促 。 因 此 , 该 系 统 必 然 会 存 在一 些 缺 陷 和 不 足 。 因 为 对 学 生 信 息 管 理 的 整 个 流 程 不 够 熟 悉 , 在 需 求 分 析 时 未 能 做到

18、 完 全 满 足 用 户 的 需 求 。尽管本管理系统存在着很多不足,但其功能全面、易于日后程序更新、数据库管理容易、界面友好、操作方便、效率高、安全性好等优点是本管理系统所必需的。通过开发这个系统,我掌握了的项目基本开发过程,用到的知识巩固了我对 JAVA 的学习,但在这次设计中的最大收获并不是掌握这几门开发工具的应用,而是学会了设计系统的思维方法,以及与同学们之间相互帮助的精神。第 八 部 分 附 录 ( 部 分 代 码 )/Database.java/import java.sql.*;import javax.naming.spi.DirStateFactory.Result;/* 连

19、接数据库的类*/public class Database private Statement stmt=null;ResultSet rs=null;private Connection conn=null;String sql;String strurl=“jdbc:mysql:/127.0.0.1:3306/studentsys“;public Database()/* 打开数据库连接*/public void OpenConn()throws ExceptiontryClass.forName(“com.mysql.jdbc.Driver“); conn=DriverManager.g

20、etConnection(strurl,“root“,“root“);conn.setAutoCommit(false);catch(Exception e) System.err.println(“OpenConn:“+e.getMessage();e.printStackTrace();/* 执行 sql 语句,返回结果集 rs*/public ResultSet executeQuery(String sql)stmt = null;rs=null;trystmt=conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultS

21、et.CONCUR_READ_ONLY);rs=stmt.executeQuery(sql);catch(SQLException e)System.err.println(“executeQuery:“+e.getMessage();e.printStackTrace();return rs; /* 执行 sql 语句*/public int executeUpdate(String sql)stmt=null;rs=null;int k=0;trystmt=conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CO

22、NCUR_READ_ONLY);k=stmt.executeUpdate(sql);mit();catch(SQLException e)System.err.println(“executeUpdate:“+e.getMessage(); e.printStackTrace();return k;public void closeStmt()trystmt.close();catch(SQLException e)System.err.println(“closeStmt:“+e.getMessage(); /* 关闭数据库连接*/public void closeConn()tryconn

23、.close();catch(SQLException ex)System.err.println(“aq.closeConn:“+ex.getMessage(); /*转换编码*/public static String toGBK(String str)try if(str=null)str = “;elsestr=new String(str.getBytes(“ISO-8859-1“),“GBK“); catch (Exception e) System.out.println(e);return str;/StuBean.java/import java.util.*;import

24、java.sql.*;import javax.swing.*;/* 有 关 学 生 信 息 数 据 库 操 作 的 类*/public class StuBean String sql;ResultSet rs = null;String sNum;String sName;String sSex;String sBirth;String sHome;String sEthnic;String sYear;String sMajor;String sCollege;String sCourse;String colName;/列 名String colValue;/列 值String col

25、Value2;/列 值int stuId;/学 生 的 新 学 号/* 添 加 学 生 信 息*/public void stuAdd(String Snum,String name, String sex, String birth, String home, String ethnic, String year, String major, String college)Database DB = new Database();this.sNum = Snum;this.sName = name;this.sSex = sex;this.sBirth = birth;this.sHome

26、= home;this.sEthnic = ethnic;this.sYear = year;this.sMajor = major;this.sCollege = college;if(sName = null|sName.equals(“)JOptionPane.showMessageDialog(null, “请 输 入 学 生 姓 名 “, “错 误 “, JOptionPane.ERROR_MESSAGE);return;elseString numS = “1“;sql = “insert into student(snum, sname,ssex,sbirth,shome,set

27、hnic,syear,smajor,scollege) values (“+sNum+“,“+sName+“,“+sSex+“,“+sBirth+“,“+sHome+“,“+sEthnic+“,“+sYear+“,“+sMajor+“,“+sCollege+“)“;tryDB.OpenConn();System.out.println(“ksadhfasdf“);DB.executeUpdate(sql);System.out.println(“ksadhfasdf“);JOptionPane.showMessageDialog(null,“成 功 添 加 一 条 新 的 纪 录 !“);ca

28、tch(Exception e)System.out.println(e);JOptionPane.showMessageDialog(null, “保 存 失 败 “, “错 误 “, JOptionPane.ERROR_MESSAGE); finally DB.closeStmt();DB.closeConn();/* 修 改 学 生 信 息*/public void stuModify(String num, String name, String sex, String birth, String home, String ethnic, String year, String maj

29、or, String college)Database DB = new Database();this.sNum = num;this.sName = name;this.sSex = sex;this.sBirth = birth;this.sHome = home;this.sEthnic = ethnic;this.sYear = year;this.sMajor = major;this.sCollege = college;if(sName = null|sName.equals(“)JOptionPane.showMessageDialog(null, “请 输 入 学 生 姓

30、名 “, “错 误 “, JOptionPane.ERROR_MESSAGE);return;else/sql = “update student set sname = “+sName+“, ssex = “+sSex+“, sbirth = “+sBirth+“, shome = “+sHome+“, sethnic = “+sEthnic+“, syear = “+sYear+“, smajor = “+sMajor+“, scollege = “+sCollege+“ where snum = “+Integer.parseInt(sNum)+“;sql = “update stude

31、nt set sname = “+sName+“, ssex = “+sSex+“, sbirth = “+sBirth+“, shome = “+sHome+“, sethnic = “+sEthnic+“, syear = “+sYear+“, smajor = “+sMajor+“, scollege = “+sCollege+“ where snum = “+sNum+“;tryDB.OpenConn();int k = DB.executeUpdate(sql);if(k = 1)JOptionPane.showMessageDialog(null,“成 功 修 改 一 条新 的 纪

32、 录 ! “);catch(Exception e)System.out.println(e);JOptionPane.showMessageDialog(null, “更 新 失 败 “, “错 误 “, JOptionPane.ERROR_MESSAGE); finally DB.closeStmt();DB.closeConn();/* 删 除 学 生 信 息*/public void stuDel(String num)Database DB = new Database();this.sNum = num;sql = “delete from student where snum =

33、 “+sNum+“;tryDB.OpenConn();DB.executeUpdate(sql);JOptionPane.showMessageDialog(null,“成 功 删 除 一 条 新 的 纪 录 ! “);catch(Exception e)System.out.println(e);JOptionPane.showMessageDialog(null, “删 除 失 败 “, “错 误 “, JOptionPane.ERROR_MESSAGE); finally DB.closeStmt();DB.closeConn();/* 根 据 学 号 查 询 学 生 信 息*/publ

34、ic String stuSearch(String num)Database DB = new Database();this.sNum = num;String s = new String8;sql = “select * from student where snum = “+sNum+“;tryDB.OpenConn();rs = DB.executeQuery(sql);if(rs.next()s0 = rs.getString(“sname“);s1 = rs.getString(“ssex“);s2 = rs.getString(“sethnic“);s3 = rs.getSt

35、ring(“shome“);s4 = rs.getString(“syear“);s5 = rs.getString(“smajor“);s6 = rs.getString(“scollege“);s7 = rs.getString(“sbirth“);elses = null;catch(Exception e)finally DB.closeStmt();DB.closeConn();return s;/* 学 生 信 息 综 合 查 询 (按 照 一 个 条 件 进 行 查 询 )*/public String stuAllSearch(String colname,String col

36、value)this.colName = colname;this.colValue = colvalue;Database DB = new Database();String sn = null;int row = 0;int i = 0;DB.toGBK(colvalue);if(colValue = null|colValue.equals(“)sql = “select * from student“;elsesql = “select * from student where “+colName+“ = “+colValue+“;tryDB.OpenConn();rs = DB.e

37、xecuteQuery(sql);if(rs.last()row = rs.getRow();if(row = 0)sn = null;elsesn = new Stringrow9;rs.first();rs.previous();while(rs.next()sni0 = rs.getString(“snum“);sni1 = rs.getString(“sname“);sni2 = rs.getString(“ssex“);sni3 = rs.getString(“sethnic“);sni4 = rs.getString(“shome“);sni5 = rs.getString(“sy

38、ear“);sni6 = rs.getString(“smajor“);sni7 = rs.getString(“scollege“);sni8 = rs.getString(“sbirth“);i+;catch(Exception e)finally DB.closeStmt();DB.closeConn();return sn;/* 学 生 信 息 综 合 查 询 (查 询 某 范 围 内 的 记 录 )*/public String stuAllSearch(String colname,String colvalue,String colvalue2)this.colName = co

39、lname;this.colValue = colvalue;this.colValue2 = colvalue2;Database DB = new Database();String sn = null;int row = 0;int i = 0;sql = “select * from student where “+colName+“ between “+colValue+“ and “+colValue2+“;tryDB.OpenConn();rs = DB.executeQuery(sql);if(rs.last()row = rs.getRow();if(row = 0)sn =

40、 null;elsesn = new Stringrow9;rs.first();rs.previous();while(rs.next()sni0 = rs.getString(“snum“);sni1 = rs.getString(“sname“);sni2 = rs.getString(“ssex“);sni3 = rs.getString(“sethnic“);sni4 = rs.getString(“shome“);sni5 = rs.getString(“syear“);sni6 = rs.getString(“smajor“);sni7 = rs.getString(“scoll

41、ege“);sni8 = rs.getString(“sbirth“);i+;catch(Exception e)finally DB.closeStmt();DB.closeConn();return sn;public String stuSearchBySimple(String course)this.sCourse = course;ResultSet rSet,rrSet;String LinCNUM = null;Database DB = new Database();String sn = null;String snnStrings = null;int row = 0;i

42、nt i = 0;int j = 0;String sql1 = “select course.* from course where ame=“+sCourse+“;String sql3 = null;tryDB.OpenConn();rSet = DB.executeQuery(sql1);if(rSet.last()row = rSet.getRow();if(row = 0)LinCNUM = null;elserSet.first();rSet.previous();while(rSet.next()LinCNUM = rSet.getString(“cnum“);System.o

43、ut.println(LinCNUM);String sql2 = “select sc.snum from sc where um=“+LinCNUM+“ order by sc.grade desc“;rrSet = DB.executeQuery(sql2);if(rrSet.last()row = rrSet.getRow();if(row = 0)snnStrings = null;elsei = 0;snnStrings = new Stringrow;sn = new Stringrow9;System.out.println(“+row);rrSet.first();rrSet

44、.previous();while(rrSet.next()snnStringsi = rrSet.getString(“snum“);sql3 = “select * from student where snum=“+snnStringsi+“;rs = DB.executeQuery(sql3);while(rs.next()snj0 = rs.getString(“snum“);snj1 = rs.getString(“sname“);snj2 = rs.getString(“ssex“);snj3 = rs.getString(“sethnic“);snj4 = rs.getStri

45、ng(“shome“);snj5 = rs.getString(“syear“);snj6 = rs.getString(“smajor“);snj7 = rs.getString(“scollege“);snj8 = rs.getString(“sbirth“);j+;i+;catch(Exception e)e.printStackTrace();finally DB.closeStmt();DB.closeConn();System.out.println(sn11);return snpublic String stuSearchBypoint()String sCourse = “编

46、 译 原 理 “;ResultSet rSet,rrSet;String LinCNUM = null;Database DB = new Database();String sn = null;String snnStrings = null;int row = 0;int i = 0;int j = 0;String sql1 = “select course.* from course where ame=“+sCourse+“;String sql3 = null;tryDB.OpenConn();rSet = DB.executeQuery(sql1);if(rSet.last()r

47、ow = rSet.getRow();if(row = 0)LinCNUM = null;elserSet.first();rSet.previous();while(rSet.next()LinCNUM = rSet.getString(“cnum“);System.out.println(LinCNUM);String sql2 = “select sc.snum from sc where um=“+LinCNUM+“ order by sc.grade desc“;rrSet = DB.executeQuery(sql2);if(rrSet.last()row = rrSet.getRow();if(row = 0)snnStrings = null;elsei = 0;snnStrings = new Stringrow;sn = new Stringrow9;System.out.println(“+row);rrSet.first();rrSet.previous();while(rrSet.next()snnStringsi

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报