Eclipse+Java+Swing+Mysql实现学生信息管理系统(上)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Eclipse+Java+Swing+Mysql实现学生信息管理系统

一、系统介绍


1.开发环境


开发工具:Eclipse2021


JDK版本:jdk1.8


Mysql版本:8.0.13


2.技术选型


Java+Swing+Mysql


3.系统功能


1.注册


2.登录


3.查询学生信息


4.增加学生信息


5.修改学生信息


6.删除学生信息


4.数据库

/*
 Navicat Premium Data Transfer
 Source Server         : MYSQL
 Source Server Type    : MySQL
 Source Server Version : 80013
 Source Host           : localhost:3306
 Source Schema         : swing_student_message
 Target Server Type    : MySQL
 Target Server Version : 80013
 File Encoding         : 65001
 Date: 25/11/2021 13:46:18
*/
SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;
-- ----------------------------
-- Table structure for t_student
-- ----------------------------
DROP TABLE IF EXISTS `t_student`;
CREATE TABLE `t_student`  (
  `sid` int(11) NOT NULL AUTO_INCREMENT,
  `sno` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `sname` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `sgender` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `sage` int(11) NULL DEFAULT NULL,
  `status` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `address` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `grade` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  PRIMARY KEY (`sid`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 11 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of t_student
-- ----------------------------
INSERT INTO `t_student` VALUES (1, '100001', '李白', '0', 18, '0', '北京', '大一');
INSERT INTO `t_student` VALUES (2, '100002', '王五', '0', 20, '0', '武汉', '大一');
INSERT INTO `t_student` VALUES (3, '100003', '李四', '0', 18, '0', '武汉', '大三');
INSERT INTO `t_student` VALUES (11, '100004', '赵六', '0', 22, '1', '长沙', '大一');
-- ----------------------------
-- Table structure for t_teacher
-- ----------------------------
DROP TABLE IF EXISTS `t_teacher`;
CREATE TABLE `t_teacher`  (
  `tid` int(11) NOT NULL AUTO_INCREMENT,
  `account` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `pass` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `username` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `sex` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  `workage` int(11) NULL DEFAULT NULL,
  `retire` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_slovenian_ci NULL DEFAULT NULL,
  `loginstatus` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_slovenian_ci NULL DEFAULT '0' COMMENT '0:未登录,1:已登录',
  PRIMARY KEY (`tid`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 35 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_slovenian_ci ROW_FORMAT = Dynamic;
-- ----------------------------
-- Records of t_teacher
-- ----------------------------
INSERT INTO `t_teacher` VALUES (35, '200001', 'e10adc3949ba59abbe56e057f20f883e', '张三', '1', 24, '1', '0');
SET FOREIGN_KEY_CHECKS = 1;

二、系统展示


1.注册系统


3a3faa8fbe964e718d6b0a86f8266188.jpg


2.登录系统


fb7c5a23bb6e4650a341d384b194a590.jpg


3.系统主页面


18d4aac24ee04e91824131f41b89b145.jpg


4.添加学生信息


cf412768caaa42b4997647f3c90fc1fc.jpg


5.修改学生信息


1b433f62bcdf44ba9591e87a3351b9dc.jpg


6.查询学生信息


fc29a7ae15bc46098ae37355a04a4923.jpg


三、部分代码


LoginFrame.java

package com.zhongbei.eams.ui;
import com.zhongbei.eams.factory.EmasFactory;
import javax.swing.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import com.zhongbei.eams.ui.MainFrame;
import java.sql.SQLException;
public class LoginFrame extends JFrame {
  private JTextField tfUsername; // 定义一个用户名输入框
  private JPasswordField pfPassword; // 定义一个密码框
  private static boolean isLogin; // 判断是否登录
  private JCheckBox ckbRemember; // 是否记住密码
  private JButton btLogin; // 定义 登录按钮
  private JButton btRegister; // 定义 关闭按钮
  public LoginFrame() {
    this.getContentPane().setLayout(null); // 绝对布局
    JLabel jlUser = new JLabel("登陆账号");// 定义登录账号标签
    jlUser.setBounds(41, 72, 82, 15);// 设置位置
    this.add(jlUser);// 添加到当前界面
    tfUsername = new JTextField(); // 定义用户名输入框
    tfUsername.setBounds(118, 64, 207, 30);// 设置位置
    this.add(tfUsername);// 添加到当前界面
    JLabel jlPassword = new JLabel("登陆密码");// 定义登录密码标签
    jlPassword.setBounds(41, 116, 82, 15);// 设置位置
    this.add(jlPassword);// 添加到当前界面
    pfPassword = new JPasswordField();// 定义密码输入框
    pfPassword.setBounds(118, 108, 207, 30);// 设置位置
    this.add(pfPassword);// 添加到当前界面
    btLogin = new JButton("登  录");// 定义登录按钮
    btLogin.setBounds(63, 206, 93, 30);// 设置位置
    btLogin.addActionListener(new ActionListener() { // 登录按钮的监听事件
      @Override
      public void actionPerformed(ActionEvent e) {
        try {
          btLoginActionPerformed();
        } catch (Exception ex) {
          ex.printStackTrace();
        }
      }
    });
    this.add(btLogin);// 添加到当前界面
    btRegister = new JButton("注 册");// 定义注册按钮
    btRegister.setBounds(221, 206, 93, 30);// 设置位置
    btRegister.addActionListener(new ActionListener() {
      public void actionPerformed(ActionEvent e) {
        // 打开注册界面
        new RegisterFrame();
        dispose();// 关闭界面
      }
    });
    this.add(btRegister);// 添加到当前界面
    setTitle("用户登录界面");
    setSize(400, 300); // 设置界面大小
    setResizable(false); // 设置界面大小不可改变
    setLocationRelativeTo(null); // 设置登录界面居中
    this.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); // 设置默认关闭操作
    this.setVisible(true);
  }
  public void btLoginActionPerformed() throws Exception {// 登录方法
    // 获取用户名和密码
    String username = tfUsername.getText().trim();
    String password = new String(pfPassword.getPassword()).trim();
    System.out.println(username + "\t" + password);
    if ("".equals(username) || null == username || "".equals(password) || null == password) {
      JOptionPane.showMessageDialog(this, "账号和密码均不可以为空");
      return;
    }
    // if(){
    // JOptionPane.showMessageDialog(this,"密码不可以为空");
    // return;
    // }
    // 登录前判断此刻教师要登录的账户是否存在,如果不存在就没有判断赋号和密码是否止确的必要
    boolean flag = EmasFactory.getTeacherServiceInstance().queryTeacherByAccount(username);
    if (flag) {
      boolean loginStatus = EmasFactory.getTeacherServiceInstance().queryLoginStatusForTeacher(username);
      if (loginStatus) {
        // flag == ture 的话表示教师此刻提交的用户名存在,按下来开始登录
        boolean temp = EmasFactory.getTeacherServiceInstance().teacherLoginSystem(username, password);
        if (temp) {
          EmasFactory.getTeacherServiceInstance().setTeacherLoginStatus(username, "1");
          // temp == ture 的话表示用户名和密码正确,可以进入系统
          JOptionPane.showMessageDialog(this, "账号密码正确,即将进入系统!");// 提示
          // 需要进入系统
          this.dispose();
          new MainFrame(username);
        } else {
          // temp == ture 的话表示用户名和密码错误,需要重新登录
          JOptionPane.showMessageDialog(this, "账号密码错误,请重新登录!");// 提示
        }
      } else {
        JOptionPane.showMessageDialog(this, "登录的账号已经处于登陆状态,不能继续登录!");
      }
    } else {
      // flag == false的话表示教师测试提交的用户名不存在(没注册,需要他重新输入)
      JOptionPane.showMessageDialog(this, "您输入的用户名不存在,请重新输入或注册!");// 提示
    }
  }
  public static void main(String[] args) {
    new LoginFrame();
  }
}


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8天前
|
存储 Java 关系型数据库
java调用mysql存储过程
在 Java 中调用 MySQL 存储过程主要借助 JDBC(Java Database Connectivity)。其核心原理是通过 JDBC 与 MySQL 建立连接,调用存储过程并处理结果。具体步骤包括:加载 JDBC 驱动、建立数据库连接、创建 CallableStatement 对象、设置存储过程参数并执行调用。此过程实现了 Java 程序与 MySQL 数据库的高效交互。
|
11天前
|
人工智能 JavaScript 关系型数据库
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
57 14
【02】Java+若依+vue.js技术栈实现钱包积分管理系统项目-商业级电玩城积分系统商业项目实战-ui设计图figmaUI设计准备-figma汉化插件-mysql数据库设计-优雅草卓伊凡商业项目实战
|
1月前
|
自然语言处理 Java 关系型数据库
Java mysql根据很长的富文本如何自动获取简介
通过使用Jsoup解析富文本并提取纯文本,然后根据需要生成简介,可以有效地处理和展示长文本内容。该方法简单高效,适用于各种应用场景。希望本文对您在Java中处理富文本并生成简介的需求提供实用的指导和帮助。
57 14
|
1月前
|
自然语言处理 Java 关系型数据库
Java mysql根据很长的富文本如何自动获取简介
通过使用Jsoup解析富文本并提取纯文本,然后根据需要生成简介,可以有效地处理和展示长文本内容。该方法简单高效,适用于各种应用场景。希望本文对您在Java中处理富文本并生成简介的需求提供实用的指导和帮助。
47 9
|
3天前
|
关系型数据库 MySQL 网络安全
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
47 25
|
12天前
|
关系型数据库 MySQL 数据库
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
91 42
|
26天前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
30天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
262 0
|
2月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
73 3
|
2月前
|
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`
117 2