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

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 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();
  }
}


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
21小时前
|
Java 关系型数据库 MySQL
【JAVA进阶篇教学】第八篇:Java链接MySql数据库异常
【JAVA进阶篇教学】第八篇:Java链接MySql数据库异常
|
1天前
|
SQL druid Java
java mysql druid mybatis-plus里使用多表删除出错的一种处理方式
java mysql druid mybatis-plus里使用多表删除出错的一种处理方式
|
4天前
|
传感器 人工智能 前端开发
JAVA语言VUE2+Spring boot+MySQL开发的智慧校园系统源码(电子班牌可人脸识别)Saas 模式
智慧校园电子班牌,坐落于班级的门口,适合于各类型学校的场景应用,班级学校日常内容更新可由班级自行管理,也可由学校统一管理。让我们一起看看,电子班牌有哪些功能呢?
45 4
JAVA语言VUE2+Spring boot+MySQL开发的智慧校园系统源码(电子班牌可人脸识别)Saas 模式
|
11天前
|
关系型数据库 MySQL Java
Java时间转换为MySQL中的INT类型时间戳
Java时间转换为MySQL中的INT类型时间戳
|
12天前
|
Java 关系型数据库 MySQL
【JDBC编程】基于MySql的Java应用程序中访问数据库与交互数据的技术
【JDBC编程】基于MySql的Java应用程序中访问数据库与交互数据的技术
|
12天前
|
Java 关系型数据库 MySQL
Java基础教程(20)-Java连接mysql数据库CURD
【4月更文挑战第19天】MySQL是流行的关系型数据库管理系统,支持SQL语法。在IDEA中加载jar包到项目类路径:右击项目,选择“Open Module Settings”,添加库文件。使用JDBC连接MySQL,首先下载JDBC驱动,然后通过`Class.forName()`加载驱动,`DriverManager.getConnection()`建立连接。执行CRUD操作,例如创建表、插入数据和查询,使用`Statement`或`PreparedStatement`,并确保正确关闭数据库资源。
|
23天前
|
Java 关系型数据库 MySQL
一套java+ spring boot与vue+ mysql技术开发的UWB高精度工厂人员定位全套系统源码有应用案例
UWB (ULTRA WIDE BAND, UWB) 技术是一种无线载波通讯技术,它不采用正弦载波,而是利用纳秒级的非正弦波窄脉冲传输数据,因此其所占的频谱范围很宽。一套UWB精确定位系统,最高定位精度可达10cm,具有高精度,高动态,高容量,低功耗的应用。
34 0
一套java+ spring boot与vue+ mysql技术开发的UWB高精度工厂人员定位全套系统源码有应用案例
|
25天前
|
缓存 小程序
Java+saas模式 智慧校园系统源码MySQL5.7+ elmentui前后端分离架构 让校园管理更高效的数字化平台系统源码
智慧校园是在数字通增强版基础上,研发的一套面向教育行业的数字化校园软件,其显著特点是集学校网站、协同办公、即时通讯、网络空间、移动办公于一体。在满足教职工日常办公需要的同时,拥有诸多教育行业功能,并提供便捷易用的“家校通”平台以满足老师、学生、家长的日常交流。数字通智慧校园教育版中的协同办公、即时通讯、移动办公等功能模块随通用版一同改进,将网络办公最新技术应用到教育行业。
27 1
|
26天前
|
传感器 小程序 Java
Java+saas模式 智慧校园系统源码Java Android +MySQL+ IDEA 多校运营数字化校园云平台源码
Java+saas模式 智慧校园系统源码Java Android +MySQL+ IDEA 多校运营数字化校园云平台源码 智慧校园即智慧化的校园,也指按智慧化标准进行的校园建设,按标准《智慧校园总体框架》中对智慧校园的标准定义是:物理空间和信息空间的有机衔接,使任何人、任何时间、任何地点都能便捷的获取资源和服务。
20 1
|
1月前
|
消息中间件 Java 关系型数据库
JAVA云HIS医院管理系统源码、基于Angular+Nginx+ Java+Spring,SpringBoot+ MySQL + MyCat
JAVA云HIS医院管理系统 常规模版包括门诊管理、住院管理、药房管理、药库管理、院长查询、电子处方、物资管理、媒体管理等,为医院管理提供更有力的保障。 HIS系统以财务信息、病人信息和物资信息为主线,通过对信息的收集、存储、传递、统计、分析、综合查询、报表输出和信息共享,及时为医院领导及各部门管理人员提供全面、准确的各种数据。
32 1

推荐镜像

更多