Java swing+MySQL实现的学生信息管理系统课程设计

简介: 这款Java swing实现的学生信息管理系统和jsp版本的功能很相似,简单的实现了班级信息的增删改查,学生信息的增删改查,数据库采用的是mysql,jdk版本不限,是Java学习者学习参考非常好的一个小项目,下面我们来看看如何运行。

这款Java swing实现的学生信息管理系统和jsp版本的功能很相似,简单的实现了班级信息的增删改查,学生信息的增删改查,数据库采用的是mysql,jdk版本不限,是Java学习者学习参考非常好的一个小项目,下面我们来看看如何运行。


将项目导入到eclipse中;

正确导入项目后我们来看下包结构:分为Dao、model、view、util四个顶层包,采用的是mvc的设计模式。

第二部需要导入数据库,我们用的是navicat数据库管理软件,非常好用,建议大家也使用这个。

首先先新建一个名为db_student_swing的数据库,然后双击新建的数据库打开。

导入项目根目录下的sql文件,导入后刷新下可以看到数据表。

配置项目中数据库连接的用户名密码。

运行登录界面的程序,即LogOnFrm类。

下面我们来看看运行截图:

下面是登陆界面,登录密码默认是admin,admin,即用户名密码都是admin。

af7d8ad6aab8edab6b3fd000a09e4ed.png

登陆进去后的主界面:

e55d0d7b402f2c8180510017d15ff56.png


先看看班级信息的管理:

班级信息添加:


454a0294180f322ba008a7ceab310cd.png

班级信息列表,在这里可以选中某一行进行修改:

5f74475b5b4c5dcc745ad3db91e3aa7.png

下面我们来看看学生信息的管理:

添加学生信息:

bedb4aa74355ebae017f63b369d5f27.png


学生信息列表:


ce4f94b19d6b0841b01dcd92d62dbe6.png

选中一个学生信息后可以修改

968ed8d95484f30245bb44c77033411.png


删除一条记录:

0f316cfaadd7d55e775be07234442ba.png


以下相关源码可以自行忽略


package com.artisan.view;
import java.awt.BorderLayout;
import java.awt.EventQueue;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.border.EmptyBorder;
import javax.swing.JMenuBar;
import javax.swing.JMenu;
import javax.swing.JMenuItem;
import javax.swing.JOptionPane;
import javax.swing.ImageIcon;
import javax.swing.JDesktopPane;
import javax.swing.GroupLayout;
import javax.swing.GroupLayout.Alignment;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
public class MainFrm extends JFrame {
  private JPanel contentPane;
  private JDesktopPane table =null;
  /**
  * Create the frame.
  */
  public MainFrm() {
  setTitle("学生信息管理系统主界面");
  setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
  setBounds(100, 100, 450, 300);
  JMenuBar menuBar = new JMenuBar();
  setJMenuBar(menuBar);
  JMenu mnNewMenu = new JMenu("\u57FA\u672C\u6570\u636E\u7EF4\u62A4");
  mnNewMenu.setIcon(new ImageIcon(MainFrm.class.getResource("/images/base.png")));
  menuBar.add(mnNewMenu);
  JMenu mnNewMenu_1 = new JMenu("班级信息管理");
  mnNewMenu_1.setIcon(new ImageIcon(MainFrm.class.getResource("/images/bookTypeManager.png")));
  mnNewMenu.add(mnNewMenu_1);
  JMenuItem menuItem = new JMenuItem("班级信息添加");
  menuItem.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent arg0) {
    SchoolClassAddInterFrm bookTypeAddInterFrm=new SchoolClassAddInterFrm();
    bookTypeAddInterFrm.setVisible(true);
    table.add(bookTypeAddInterFrm);
    }
  });
  menuItem.setIcon(new ImageIcon(MainFrm.class.getResource("/images/add.png")));
  mnNewMenu_1.add(menuItem);
  JMenuItem menuItem_1 = new JMenuItem("班级信息维护");
  menuItem_1.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent arg0) {
    SchoolClassManageInterFrm bookTypeManageInterFrm=new SchoolClassManageInterFrm();
    bookTypeManageInterFrm.setVisible(true);
    table.add(bookTypeManageInterFrm);
    }
  });
  menuItem_1.setIcon(new ImageIcon(MainFrm.class.getResource("/images/edit.png")));
  mnNewMenu_1.add(menuItem_1);
  JMenu mnNewMenu_2 = new JMenu("学生信息管理");
  mnNewMenu_2.setIcon(new ImageIcon(MainFrm.class.getResource("/images/bookManager.png")));
  mnNewMenu.add(mnNewMenu_2);
  JMenuItem menuItem_2 = new JMenuItem("学生信息添加");
  menuItem_2.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent arg0) {
    StudentAddInterFrm bookAddInterFrm=new StudentAddInterFrm();
    bookAddInterFrm.setVisible(true);
    table.add(bookAddInterFrm);
    }
  });
  menuItem_2.setIcon(new ImageIcon(MainFrm.class.getResource("/images/add.png")));
  mnNewMenu_2.add(menuItem_2);
  JMenuItem menuItem_3 = new JMenuItem("学生信息维护");
  menuItem_3.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent arg0) {
    StudentManageInterFrm bookManageInterFrm=new StudentManageInterFrm();
    bookManageInterFrm.setVisible(true);
    table.add(bookManageInterFrm);
    }
  });
  menuItem_3.setIcon(new ImageIcon(MainFrm.class.getResource("/images/edit.png")));
  mnNewMenu_2.add(menuItem_3);
  JMenuItem menuItem_4 = new JMenuItem("\u5B89\u5168\u9000\u51FA");
  menuItem_4.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent e) {
    int result=JOptionPane.showConfirmDialog(null, "是否退出系统");
    if(result==0){
      dispose();
    }
    }
  });
  menuItem_4.setIcon(new ImageIcon(MainFrm.class.getResource("/images/exit.png")));
  mnNewMenu.add(menuItem_4);
  JMenu menu = new JMenu("关于系统");
  menu.setIcon(new ImageIcon(MainFrm.class.getResource("/images/about.png")));
  menuBar.add(menu);
  JMenuItem mntmjava = new JMenuItem("关于");
  mntmjava.addActionListener(new ActionListener() {
    public void actionPerformed(ActionEvent arg0) {
    ArtisanInterFrm java1234InterFrm=new ArtisanInterFrm();
    java1234InterFrm.setVisible(true);
    table.add(java1234InterFrm);
    }
  });
  mntmjava.setIcon(new ImageIcon(MainFrm.class.getResource("/images/about.png")));
  menu.add(mntmjava);
  contentPane = new JPanel();
  contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
  setContentPane(contentPane);
  contentPane.setLayout(new BorderLayout(0, 0));
  table = new JDesktopPane();
  contentPane.add(table, BorderLayout.CENTER);
  // 设置JFrame最大化
  this.setExtendedState(JFrame.MAXIMIZED_BOTH);
  }
}


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
7月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
3月前
|
SQL Java 关系型数据库
Java连接MySQL数据库环境设置指南
请注意,在实际部署时应该避免将敏感信息(如用户名和密码)硬编码在源码文件里面;应该使用配置文件或者环境变量等更为安全可靠地方式管理这些信息。此外,在处理大量数据时考虑使用PreparedStatement而不是Statement可以提高性能并防止SQL注入攻击;同时也要注意正确处理异常情况,并且确保所有打开过得资源都被正确关闭释放掉以防止内存泄漏等问题发生。
154 13
|
10月前
|
存储 Java 关系型数据库
java调用mysql存储过程
在 Java 中调用 MySQL 存储过程主要借助 JDBC(Java Database Connectivity)。其核心原理是通过 JDBC 与 MySQL 建立连接,调用存储过程并处理结果。具体步骤包括:加载 JDBC 驱动、建立数据库连接、创建 CallableStatement 对象、设置存储过程参数并执行调用。此过程实现了 Java 程序与 MySQL 数据库的高效交互。
|
5月前
|
人工智能 Java 关系型数据库
Java的时间处理与Mysql的时间查询
本文总结了Java中时间与日历的常用操作,包括时间的转换、格式化、日期加减及比较,并介绍了MySQL中按天、周、月、季度和年进行时间范围查询的方法,适用于日常开发中的时间处理需求。
108 0
|
10月前
|
人工智能 JavaScript 关系型数据库
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
394 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
|
11月前
|
自然语言处理 Java 关系型数据库
Java mysql根据很长的富文本如何自动获取简介
通过使用Jsoup解析富文本并提取纯文本,然后根据需要生成简介,可以有效地处理和展示长文本内容。该方法简单高效,适用于各种应用场景。希望本文对您在Java中处理富文本并生成简介的需求提供实用的指导和帮助。
217 9
|
12月前
|
存储 IDE Java
漂亮不是梦!Java Swing美化攻略
Java Swing 是一个为 Java 设计的 GUI 工具包,提供文本框、按钮等组件。尽管其外观可定制,通过 Look and Feel(LAF)机制改变应用风格,如 Darcula 和 FlatLaf,但现已淡出主流视野,主要应用于 IDE 领域,如 IntelliJ IDEA 和 Eclipse。相比其他 GUI 框架,Swing 的发展前景有限。
482 1
|
3月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
165 3
|
3月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
3月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
802 152

推荐镜像

更多