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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 这款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);
  }
}


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
24天前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
115 26
|
11天前
|
存储 IDE Java
漂亮不是梦!Java Swing美化攻略
Java Swing 是一个为 Java 设计的 GUI 工具包,提供文本框、按钮等组件。尽管其外观可定制,通过 Look and Feel(LAF)机制改变应用风格,如 Darcula 和 FlatLaf,但现已淡出主流视野,主要应用于 IDE 领域,如 IntelliJ IDEA 和 Eclipse。相比其他 GUI 框架,Swing 的发展前景有限。
28 1
|
27天前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
2月前
|
关系型数据库 MySQL Java
MySQL索引优化与Java应用实践
【11月更文挑战第25天】在大数据量和高并发的业务场景下,MySQL数据库的索引优化是提升查询性能的关键。本文将深入探讨MySQL索引的多种类型、优化策略及其在Java应用中的实践,通过历史背景、业务场景、底层原理的介绍,并结合Java示例代码,帮助Java架构师更好地理解并应用这些技术。
54 2
|
2月前
|
监控 前端开发 Java
【技术开发】接口管理平台要用什么技术栈?推荐:Java+Vue3+Docker+MySQL
该文档介绍了基于Java后端和Vue3前端构建的管理系统的技术栈及功能模块,涵盖管理后台的访问、登录、首页概览、API接口管理、接口权限设置、接口监控、计费管理、账号管理、应用管理、数据库配置、站点配置及管理员个人设置等内容,并提供了访问地址及操作指南。
|
11天前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
38 3
|
11天前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
38 3
|
11天前
|
SQL 关系型数据库 MySQL
数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog
《数据库灾难应对:MySQL误删除数据的救赎之道,技巧get起来!之binlog》介绍了如何利用MySQL的二进制日志(Binlog)恢复误删除的数据。主要内容包括: 1. **启用二进制日志**:在`my.cnf`中配置`log-bin`并重启MySQL服务。 2. **查看二进制日志文件**:使用`SHOW VARIABLES LIKE 'log_%';`和`SHOW MASTER STATUS;`命令获取当前日志文件及位置。 3. **创建数据备份**:确保在恢复前已有备份,以防意外。 4. **导出二进制日志为SQL语句**:使用`mysqlbinlog`
52 2
|
24天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
168 15
|
17天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。