Java 学生信息管理系统-窗体程序 有详细设计文档和报告

今天为大家分享一个java语言编写的学生信息管理系统,目前系统功能已经很全面,后续会进一步完善。整个系统界面漂亮,有完整得源码,希望大家可以喜欢。喜欢的帮忙点赞和关注。一起编程、一起进步

开发环境

开发语言为Java,开发环境Eclipse或者IDEA都可以。数据库采用:MySQL。运行主程序,或者执行打开JAR文件即可以运行本程序。

系统框架

利用JDK自带的SWING框架开发,不需要安装第三方JAR包。MySQL数据库,纯窗体模式,直接运行Main文件即可以。同时带有详细得设计文档

主要功能

开发背景

随着高校的扩招,需要处理的学生信息日趋加大,不仅花费大量的教师资源,处理的效率还十分低下。为提高学生管理的管理水平,优化资源,尽可能降低管理成本成为学生管理的新课题,学生管理系统是从学生管理现状出发,根据学生管理的新要求进行开发设计的,它解决了学生管理数据信息量大,修改不方便,对一系列数据进行分析时花费时间长等问题,帮助学生管理人员有效管理学生信息,成为管理高校中必不可少的管理工具。

主要功能

本次课程设计开发一个学生管理系统,系统中分两类系统管理员和普通学生。系统管理员能对系统中的学生进行查询,增加,删除,修改,分页显示,Excel导出学生信息等。

运行效果

1 用户登陆

2 主界面

3 添加学生界面

4 学生信息查询

5 学生查询结果展示

6 关于系统

7 导出Excel

核心代码

/*
 * 登陆成功后主界面
 */
public class MainMenu extends JFrame implements ActionListener{
    private JFrame mainmenu;
    private JTextArea text;
    private JMenu menuFile1, menuFile2, menuFile3;
    private JMenuBar menuBar1;
    private JMenuItem addStudentInfo,queryStudentInfo, modifyPassword,Exit;
    private JMenuItem importExcel,importTxt, outputExcel,outputTxt;
    private JMenuItem aboutSystem,help;
    public MainMenu() {

        mainmenu();
    }

    public void mainmenu() {
        // TODO Auto-generated method stub
        text = new JTextArea("欢迎使用");
        text.setEditable(true);
        mainmenu = new JFrame("欢迎使用学生信息管理系统 - 欢迎" + "用户" );
        mainmenu.setSize(1265, 856);

        mainmenu.getContentPane().add(new JScrollPane(text));


        //====================>基本操作
        menuFile1 = new JMenu("基本操作(0)");
        Font font = new Font("楷体",Font.BOLD,16);
        menuFile1.setFont(font);
        menuFile1.setIcon(new ImageIcon("src/images/icons/base1.png"));
        menuFile1.setMnemonic('O');
        //menuFile.setAccelerator(KeyStroke.getKeyStroke('O',java.awt.Event.ALT_MASK));

        add(menuFile1);

        menuBar1 = new JMenuBar();

        addStudentInfo = new JMenuItem("增加",new ImageIcon("src/images/icons/add.png"));
        addStudentInfo.setMnemonic('H');
        addStudentInfo.setAccelerator(KeyStroke.getKeyStroke('H',java.awt.Event.CTRL_MASK));
        menuFile1.add(addStudentInfo);

        queryStudentInfo = new JMenuItem("查询",new ImageIcon("src/images/icons/query.png"));
        queryStudentInfo.setMnemonic('Q');
        queryStudentInfo.setAccelerator(KeyStroke.getKeyStroke('Q',java.awt.Event.CTRL_MASK));
        menuFile1.add(queryStudentInfo);

        modifyPassword = new JMenuItem("密码修改",new ImageIcon("src/images/icons/modifyPassword.png"));
        modifyPassword.setMnemonic('M');
        modifyPassword.setAccelerator(KeyStroke.getKeyStroke('M',java.awt.Event.CTRL_MASK));
        menuFile1.add(modifyPassword);

        Exit = new JMenuItem("退出",new ImageIcon("src/images/icons/exit.png"));
        Exit.setMnemonic('E');
        Exit.setAccelerator(KeyStroke.getKeyStroke('E',java.awt.Event.CTRL_MASK));
        menuFile1.add(Exit);

        menuBar1.add(menuFile1);

        //====================>导入导出
        menuFile2 = new JMenu("导入导出(0)");
        menuFile2.setFont(font);
        menuFile2.setIcon(new ImageIcon("src/images/icons/base2.png"));
        menuFile2.setMnemonic('O');
        //menuFile.setAccelerator(KeyStroke.getKeyStroke('O',java.awt.Event.ALT_MASK));
        importExcel = new JMenuItem("从excel导入",new ImageIcon("src/images/icons/import.png"));
        importExcel.setMnemonic('H');
        importExcel.setAccelerator(KeyStroke.getKeyStroke('H',java.awt.Event.CTRL_MASK));
        menuFile2.add(importExcel);

        importTxt = new JMenuItem("从txt导入",new ImageIcon("src/images/icons/output.png"));
        importTxt.setMnemonic('H');
        importTxt.setAccelerator(KeyStroke.getKeyStroke('H',java.awt.Event.CTRL_MASK));
        menuFile2.add(importTxt);

        outputExcel = new JMenuItem("从excel导出",new ImageIcon("src/images/icons/import1.png"));
        outputExcel.setMnemonic('H');
        outputExcel.setAccelerator(KeyStroke.getKeyStroke('H',java.awt.Event.CTRL_MASK));
        menuFile2.add(outputExcel);

        outputTxt = new JMenuItem("从txt导出",new ImageIcon("src/images/icons/output1.png"));
        outputTxt.setMnemonic('H');
        outputTxt.setAccelerator(KeyStroke.getKeyStroke('H',java.awt.Event.CTRL_MASK));
        menuFile2.add(outputTxt);


        menuBar1.add(menuFile2);

        //====================>帮助
        menuFile3 = new JMenu("帮助(0)");
        menuFile3.setFont(font);
        menuFile3.setIcon(new ImageIcon("src/images/icons/base3.png"));
        menuFile3.setMnemonic('O');
        //menuFile.setAccelerator(KeyStroke.getKeyStroke('O',java.awt.Event.ALT_MASK));
        aboutSystem = new JMenuItem("关于本系统",new ImageIcon("src/images/icons/about.png"));
        aboutSystem.setMnemonic('H');
        aboutSystem.setAccelerator(KeyStroke.getKeyStroke('H',java.awt.Event.CTRL_MASK));
        menuFile3.add(aboutSystem);

        help = new JMenuItem("系统帮助",new ImageIcon("src/images/icons/help.png"));
        help.setMnemonic('H');
        help.setAccelerator(KeyStroke.getKeyStroke('H',java.awt.Event.CTRL_MASK));
        menuFile3.add(help);

        menuBar1.add(menuFile3);




        addStudentInfo.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘添加学生信息’菜单项");
                AddStudentInfo addStudentInfo = new AddStudentInfo();
            }
        });


        queryStudentInfo.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘查询学生信息’菜单项");
                QueryStudentInfo queryStudentInfo = new QueryStudentInfo();
            }
        });

        modifyPassword.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘修改密码’菜单项");
                ModifyPasswordInfo modifyPasswordInfo = new ModifyPasswordInfo();
            }
        });


        Exit.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘退出’菜单项");
                System.exit(1);
            }
        });

        importExcel.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘导入到excel’菜单项");
                ImportExcel importExcel =new ImportExcel();

            }
        });
        importTxt.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘导入到txt’菜单项");
                ImportTxt importTxt = new ImportTxt();
            }
        });
        outputExcel.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘导出到excel’菜单项");
                OutputExcel outputExcel = new OutputExcel();
            }
        });
        outputTxt.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘导出到txt’菜单项");
                OutputTxt outputTxt = new OutputTxt();
            }
        });
        aboutSystem.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘关于系统’菜单项");
                AboutSystem aboutSystem = new AboutSystem();
            }
        });
        help.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                System.out.println("=======>用户选择了‘帮助’菜单项");
                Help help = new Help();
            }
        });


        mainmenu.addWindowListener(new WindowAdapter() {
            public void windowClosing(WindowEvent arg0) {
                System.exit(1);
            }
        });

        mainmenu.setJMenuBar(menuBar1);
        mainmenu.setVisible(true);
        mainmenu.setLocation(250, 50);
        addStudentInfo.addActionListener(this);
        queryStudentInfo.addActionListener(this);
        modifyPassword.addActionListener(this);
        Exit.addActionListener(this);
        importExcel.addActionListener(this);
        importTxt.addActionListener(this);
        outputExcel.addActionListener(this);
        outputTxt.addActionListener(this);
        aboutSystem.addActionListener(this);
        help.addActionListener(this);
    }



    public static void main(String[] args) {
        new MainMenu();

    }

    @Override
    public void actionPerformed(ActionEvent arg0) {


    }

}

项目总结

当查询学生信息的时候,符合条件的学生记录数据有多条的时候,分页技术是一个难点,分页技术的主要实现步骤有以下几个步骤 :

1 根据符合的条件到数据库中查询,利用count(*)函数统计出符合条件的函数

2 根据每页5条件,根据总记录数,计算出符合条件的页面数量。计算公式为

(int) Math.ceil(totalrecord/5.0);

3 把查询出来的list记录传递到页面的前台进行显示

开发一套系统,最重要的是细心,并不是一定要做到面面俱到,在准备工作中要正确分析社会需求了解现实应用,画出流程图,把大体框架做好,然后再逐一细化。我们不可能做到面面俱到,但一定要做到步步扎实,作为一个程序编程人员,要保持清醒的头脑,以现实为依据,让自己的每一行代码都能实现自己的意义。 通过这次项目设计,我收获的不仅仅是课程上的知识得到实际应用,还有编程的基本习惯和开发系统时应注意的流程。

  • 4
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
JAVA程序设计 课程设计报告 课 题: 学生信息管理系统 姓 名: 学 号: 同组姓名: 专业班级: 指导教师: 设计时间:   目 录 一、系统描述 2 1、需要实现的功能 3 2、设计目的 3 二、分析与设计 3 1、功能模块划分 3 2、数据库结构描述 4 3、系统详细设计文档 6 4、各个模块的实现法描述 9 5、测试数据及期望结果 11 三、系统测试 16 四、心得体会 23 五、参考文献 24 六、附录 24 一、系统描述 1、需现的功能 1.1、录入学生基本信息的功能 学生基本信息主要包括:学号、姓名、年龄、出生地、专业、班级总学分,在插入 时,如果数据库已经存在该学号,则不能再插入该学号。 1.2、修改学生基本信息的功能 在管理员模式下,只要在表格中选中某个学生,就可以对该学生信息进行修改。 1.3、查询学生基本信息的功能 可使用 "姓名"对已存有的学生资料进行查询。 1.4、删除学生基本信息的功能 在管理员模式下,只要选择表格中的某个学生,就可以删除该学生。 1.5、用户登陆 用不同的登录权限可以进入不同的后台界面,从而实现权限操作。 1.6、用户登陆信息设置 可以修改用户登陆密码 2、设计目的 学生信息管理系统是一个教育单位不可缺少的部分。一个功能齐全、简单易用的信息 管理系统不但能有效地减轻学校相关工作人员的工作负担,它的容对于学校的决策者和 管理者来说都至关重要。所以学生信息管理系统应该能够为用户提供充足的信息和快捷 的查询手段。但一直以来人们使用传统人工的式管理文件档案、统计和查询数据,这种 管理式存在着多缺点,如:效率低、保密性差、人工的大量浪费;另外时间一长,将产 生大量的文件和数据,这对于查找、更新和维护都带来了不少困难。随着科学技术的不 断提高,计算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的 各个领域并发挥着越来越重要的作用。 作为计算机应用的一部分,使用计算机对学校的各类信息进行管理,具有手工管理无 法比拟的优点。例如:检索迅速、查询便、效率高、可靠性好、存储量大、保密性好、 寿命长、成本低等。这些优点能够极大地提高学校信息管理的效率,也是一个单位科学 化、正规化管理,与世界接轨的重要条件。 本系统是将现代化的计算机技术和传统的教学、教务工作相结合,按照学院的工作流 程设计完成的。通过一个简化的学生信息管理系统,使学生信息管理工作系统化、规化 、自动化,从而达到提高学生信息管理效率的目的。 二、分析与设计 1、功能模块划分 图1 功能模块划分图 2、数据库结构描述 2.1、数据库E-R模型 图2 登录用户管理E-R图 图3 实体学生E-R图 2.2、数据库关系模型——二维表 表1 学生表(student) "字段 "数据类型 "说明 " "stuId "nvarchar(30) "学号 " "stuName "nvarchar(30) "姓名 " "stuSex "nvarchar(30) "性别 " "stuAge "int "年龄 " "stuJg "nvarchar(30) "籍贯 " "stuZy "nvarchar(30) "专业 " "classId "nvarchar(30) "班号 " "stuSourse "numeric(5,2) "总学分 " 图4 录入数据后的学生表 表2 登陆权限表(login) "字段 "数据类型 "说明 " "userId "nvarchar(30) "用户名(账号),即登 " " " "陆Id " "password "nvarchar(30) "登陆密码 " "position "nvarchar(30) "职位,如班委,普通学 " " " "生 " 图5 录入数据后的登陆权限表 3、系统详细设计文档 3.1、系统执行流程图 图6 系统执行流程图 3.2、类的划分 表3 学生信息查询类 "类名 "类的成员属性与法 "说明 " "StuQuery.jav"JPanel jp1 "定义一个面板 " "a " " " " "JLabel jp1_jl1 "定义两个标签 " " "JTextField jp1_jtf1 "定义一个文本输入框 " " "JButton "定义三个按钮 " " "jp1_jb1,jp1_jb2,jp1_jb3 " " " "JTable jtb "定义一个表 " " "JScrollPane jsp "定义一个滚动面板,用于" " " "存放表 " " "TableModel tm "自定义一个表模型,用于" " " "更新表数据 " " "public StuQuery(Frame "构造法,通过传递三个参" " "Main,String title ,boolean "数,实现对话 " " "
目 录 概述 3 一、 课题介绍 3 二、 目的和要求 3 三、 任务计划 3 需求分析 5 一、 学生管理系统的发展现状 5 二、 系统功能分析 5 三、 系统结构框图 5 数据库设计 7 一、 创建数据表的结构 7 二、 各表功能及其关系 7 系统模块功能的实现与界面设计 8 一、 系统主要模块 8 二、 欢迎界面 9 三、 主菜单界面 9 四、 子菜单 10 五、 学生信息录入 11 六、 学生信息查找 12 七、 学生信息删除 13 八、 学生信息修改 14 课程设计心得 15 一、 程序结构设计培养 15 二、 书写习惯养成 15 三、 注意程序简洁 15 总结 16 参考文献 17 附录:项目源代码 18 一、 数据库连接(DbConnection.java) 18 二、 学生信息数据库管理(Student_Dao.java) 18 三、 欢迎界面(Welcome.java) 23 四、 主菜单界面(Menu.java) 24 五、 子菜单界面(Son_Menu.java) 27 六、 添加功能(Add_Menu.java) 31 七、 查找功能(Find_Menu.java) 34 八、 删除功能(Delet_Menu.java) 36 九、 修改功能(Change_Menu.java) 38 概述 课题介绍 本次课程设计要求实现一个面向学生信息的管理系统。学生信息系统是一个非常通用 的管理系统。很多大、中、小学校都需要拥有自己的学生档案管理系统,以便对本校学 生的基本信息和学习情况进行管理,另一方面,较完整的学校信息管理系统同样也需要 有学生信息管理系统的支持。 由通用的学生相关数据分析可知,系统包括院系管理、学生基本信息管理、课程管理 、学生从成绩管理等主要功能。 该系统要求使用JAVAMySQL作为开发工具和数据库管理系统,因此,系统设计涉及 系统功能设计数据库设计和系统界面等几个方面内容。 目的和要求 了解JAVA语言的特点及使用的范围,掌握开发软件平台的搭建。 要求使用JAVAMySQL开发一个学生信息管理系统,系统主要功能如下: 1) 院系信息管理 院系系统信息的录入,包括院系编号、院系名称等信息; 院系信息的修改、删除、查询。 2) 学生基本信息管理 学生基本信息的录入,包括学号、姓名、性别、出生日期、所在院系、班级等信息; 学生基本信息的修改、删除、查询。 3) 课程设置管理 课程信息的录入,包括课程编号、课程名称、学分、课程内容等信息; 课程信息的修改、删除、查询。 4) 学生成绩管理 学生成绩的录入,包括课程编号、课程名称、学分、课程内容等信息; 学生信息的修改、删除、查询。 任务计划 考虑到本次课程设计是独立完成,所以,不需要进行细致的分工,只要对框架和时间 进行一定的规划就行。 " "时间 "计划 "执行结果 " "1 "12月13日 "查阅相关资料 "查阅了JAVA Swing,MySQL等方面的 " " " "准备好基础知识 "相关资料。 " "2 "12月14日 "进行需求分析 "得到需求分析总结。 " "3 "12月14日~21日 "正式设计 "完成代码设计及调试 " "5 "12月22日 "完成课程设计报告"整理文件,并完成书面报告 " 需求分析 学生管理系统的发展现状 经过了一段时间的发展,当今,各大高校普遍都有了相对完善的学生管理系统,但在 部分中小学中,这种高效的管理手段,仍未能全面普及。目前已有的学生管理系统存在 界面和操作相对繁琐,实现成本较高等缺点,仍需改进。 系统功能分析 由通用的学生相关数据分析可知,系统包括院系管理、学生基本信息管理、课程管理 、学生从成绩管理等主要功能[1]。 实现以上各模块的功能,需要以下子功能: 1数据库连接的建立与断开 2数据库的数据操作,包括插入、查询、删除、修改 系统操作界面与数据库操作相关联 系统结构框图 从系统功能表述可以看出,该系统可以实现几个功能,根据这些功能设计出系统的功 能模块如 图表 1所示: 数据库设计 创建数据表的结构 (以学生基本信息管理系统为例) 主要数据项 学号、姓名、性别、出生年月、所在院系、所在班级 数据类型及要求 为操作方便,均定义为字符串。其中学号不得重复。 MySQL建表语句 各表功能及其关系 本系统各表分别存储相应数据。 涉及的数据表之间相对独立,但仍有少量关联。 1) 学生成绩表 包含对 学生基本信息表 和 课程设置表 的映射 5) 学生基本信息表 包含对 院系信息表 的映射 系统模块功能的实现与界面设计 系统主要模块 本次课程设计的主要目的,是通过实践,让我对所学到的知识进行考验和巩固。经过 一点时间的了解。设计出了系统的总体框架,参看图表 1。 由于各模块的功能及原理基本相同,只是涉及的

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

计算机程序

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值