Eclipse+Java+Swing+mysql实现学生宿舍管理系统

news2025/1/12 1:43:52

Eclipse+Java+Swing+mysql实现学生宿舍管理系统

  • 一、系统介绍
    • 1.环境配置
  • 二、系统展示
    • 1.登录页
    • 2.学生主页面
    • 3.学生端-登记页面
    • 4.学生端-学生信息修改
    • 5.学生端-寝室信息查询
    • 6.学生端-学生信息查询
    • 7.学生端-退出登录
    • 8.管理员-主页面
    • 9.管理员-宿舍信息修改
    • 10.管理员-宿舍信息删除
    • 11.管理员-学生信息修改
    • 12.管理员-学生信息删除
    • 13.管理员-宿舍信息添加
    • 14.管理员-学生信息添加
    • 15.管理员-学生信息查询
    • 16.管理员-宿舍信息查询
    • 17.管理员-关于系统
    • 18.管理员-退出系统
  • 三、部分代码
    • RoomDao.java
    • LoginFrame.java
    • Room.java
  • 四、其他
    • 获取源码


一、系统介绍

本系统实现了学生登录和管理员登录,学生可以登记入住,实现学生信息查询和修改,实现宿舍信息查询。管理实现学生信息增删改查,实现宿舍信息增删改查。

1.环境配置

JDK版本:1.8
Mysql:5.7

二、系统展示

1.登录页

在这里插入图片描述

学生账号:学生,密码都是123
管理员账号:管理员,密码都是123456

2.学生主页面

在这里插入图片描述

3.学生端-登记页面

在这里插入图片描述

4.学生端-学生信息修改

在这里插入图片描述

5.学生端-寝室信息查询

在这里插入图片描述

6.学生端-学生信息查询

在这里插入图片描述

7.学生端-退出登录

在这里插入图片描述

8.管理员-主页面

在这里插入图片描述

9.管理员-宿舍信息修改

在这里插入图片描述

10.管理员-宿舍信息删除

在这里插入图片描述

11.管理员-学生信息修改

在这里插入图片描述

12.管理员-学生信息删除

在这里插入图片描述

13.管理员-宿舍信息添加

在这里插入图片描述

14.管理员-学生信息添加

在这里插入图片描述

15.管理员-学生信息查询

在这里插入图片描述

16.管理员-宿舍信息查询

在这里插入图片描述

17.管理员-关于系统

在这里插入图片描述

18.管理员-退出系统

在这里插入图片描述

三、部分代码

RoomDao.java

package cn.com.dao;


import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

import cn.com.model.Room;
import cn.com.util.StringUtil;

/**
 * 
 * 操作宿舍信息
 *
 */
public class RoomDao {

	// 添加宿舍信息
	public int roomAdd(Connection con, Room room) throws Exception {
		String sql = "insert into room_message values(null,?,?)";
		PreparedStatement pstmt = con.prepareStatement(sql);
		pstmt.setString(1, room.getMember());
		pstmt.setString(2, room.getLeader());
		return pstmt.executeUpdate();
	}

	// 查询宿舍信息
	public ResultSet roomList(Connection con, Room room) throws Exception {
		StringBuffer sb = new StringBuffer("select * from room_message");
		if (StringUtil.isNotEmpty(room.getMember())) {
			String member = room.getMember();
			sb.append(" and member like '%" + room.getMember() + "%'");
		}
		PreparedStatement pstmt = con.prepareStatement(sb.toString().replaceFirst("and", "where"));
		return pstmt.executeQuery();
	}

	// 修改宿舍信息
	public int roomModify(Connection con, Room room) throws Exception {
		String sql = "update room_message set member=?,leader=? where id=?";
		PreparedStatement pstmt = con.prepareStatement(sql);
		pstmt.setString(1, room.getMember());
		pstmt.setString(2, room.getLeader());
		pstmt.setString(3, room.getId());
		return pstmt.executeUpdate();
	}

	// 删除宿舍信息
	public int roomDelete(Connection con, Room room) throws Exception {
		String sql = "delete from room_message where member=?";
		PreparedStatement pstmt = con.prepareStatement(sql);
		pstmt.setString(1, room.getMember());
		return pstmt.executeUpdate();
	}
}



LoginFrame.java

package cn.com.view;



import java.awt.Font;
import java.sql.Connection;

import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JComboBox;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPasswordField;
import javax.swing.JTextField;
import javax.swing.UIManager;

import cn.com.dao.UserDao;
import cn.com.model.User;
import cn.com.util.DBConn;
import cn.com.util.StringUtil;

/**
 * 
 * 登录界面
 * 
 */
public class LoginFrm extends javax.swing.JFrame {

	private JLabel jLabel1;
	private JLabel jLabel2;
	private JLabel jLabel3;
	private JLabel jLabel4;
	private JButton jb_login;
	private JButton jb_reset;
	private JComboBox jcb_choose;
	private JTextField userNameTxt;
	private JPasswordField userPasswordTxt;

	DBConn dmutil = new DBConn();
	UserDao userdao = new UserDao();

	/**
	 * 创建窗体
	 */
	public LoginFrm() {

		Font font = new Font("Dialog", Font.PLAIN, 12);
		java.util.Enumeration keys = UIManager.getDefaults().keys();
		while (keys.hasMoreElements()) {
			Object key = keys.nextElement();
			Object value = UIManager.get(key);
			if (value instanceof javax.swing.plaf.FontUIResource) {
				UIManager.put(key, font);
			}
		}
		// 初始化
		initComponents();
		// 居中
		this.setLocationRelativeTo(null);
		this.filltable();
	}

	// 填充表格
	private void filltable() {
		User user1 = new User();
		User user2 = new User();
		user1.setUsername("学生");
		user2.setUsername("管理员");
		user1.setId(1 );
		user2.setId(2 );
		jcb_choose.addItem(user1);
		jcb_choose.addItem(user2);
	}

	// 初始化
	private void initComponents() {

		jLabel1 = new JLabel("General", JLabel.CENTER);
		jLabel2 = new JLabel();
		jLabel3 = new JLabel();
		userNameTxt = new JTextField();
		userPasswordTxt = new JPasswordField();
		jb_login = new JButton();
		jb_reset = new JButton();
		jcb_choose = new JComboBox();
		jLabel4 = new JLabel();

		setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
		setTitle("学生宿舍管理系统登录界面");
		setResizable(false);

		jLabel1.setFont(new Font("宋体", 0, 24));
		jLabel1.setText("学生宿舍管理系统");

		// 用户名
	
		jLabel2.setText("账号:");

		// 密码
		
		jLabel3.setText("密码:");

		userNameTxt.addActionListener(new java.awt.event.ActionListener() {
			public void actionPerformed(java.awt.event.ActionEvent evt) {
				userNameTxtActionPerformed(evt);
			}
		});

		// 登录
	
		jb_login.setText("登录");
		jb_login.addActionListener(new java.awt.event.ActionListener() {
			public void actionPerformed(java.awt.event.ActionEvent evt) {
				jb_loginActionPerformed(evt);
			}
		});

		// 重置
	
		jb_reset.setText("重置");
		jb_reset.addActionListener(new java.awt.event.ActionListener() {
			public void actionPerformed(java.awt.event.ActionEvent evt) {
				jb_resetActionPerformed(evt);
			}
		});

	
		jLabel4.setText("用户类型:");

		javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
		getContentPane().setLayout(layout);

		layout.setHorizontalGroup(
				layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
						.addGroup(layout.createSequentialGroup().addGap(103, 103, 103).addComponent(jLabel1)
								.addContainerGap(58, Short.MAX_VALUE))
						.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout
								.createSequentialGroup().addGroup(layout.createParallelGroup(
										javax.swing.GroupLayout.Alignment.TRAILING).addGroup(
												layout.createSequentialGroup().addContainerGap().addComponent(
														jLabel4).addGap(42, 42, 42).addComponent(jcb_choose,
																javax.swing.GroupLayout.PREFERRED_SIZE, 111,
																javax.swing.GroupLayout.PREFERRED_SIZE))
										.addGroup(layout.createSequentialGroup()
												.addGroup(layout.createParallelGroup(
														javax.swing.GroupLayout.Alignment.LEADING)
														.addGroup(layout.createSequentialGroup().addGap(103, 103, 103)
																.addGroup(layout.createParallelGroup(
																		javax.swing.GroupLayout.Alignment.TRAILING)
																		.addComponent(jLabel3).addComponent(jLabel2)))
														.addGroup(layout
																.createSequentialGroup().addGap(104, 104, 104)
																.addComponent(jb_login)))
												.addGroup(layout
														.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
														.addGroup(layout.createSequentialGroup().addGap(42, 42, 42)
																.addGroup(layout.createParallelGroup(
																		javax.swing.GroupLayout.Alignment.LEADING)
																		.addComponent(userNameTxt,
																				javax.swing.GroupLayout.DEFAULT_SIZE,
																				111, Short.MAX_VALUE)
																		.addComponent(userPasswordTxt,
																				javax.swing.GroupLayout.DEFAULT_SIZE,
																				111, Short.MAX_VALUE)))
														.addGroup(javax.swing.GroupLayout.Alignment.TRAILING,
																layout.createSequentialGroup().addPreferredGap(
																		javax.swing.LayoutStyle.ComponentPlacement.RELATED)
																		.addComponent(jb_reset).addGap(25, 25, 25)))))
								.addGap(100, 100, 100)));
		
		layout.setVerticalGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING).addGroup(layout
				.createSequentialGroup().addGap(60, 60, 60).addComponent(jLabel1)
				.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
				.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE).addComponent(jLabel2)
						.addComponent(userNameTxt, javax.swing.GroupLayout.PREFERRED_SIZE,
								javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
				.addGap(27, 27, 27)
				.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE).addComponent(jLabel3)
						.addComponent(userPasswordTxt, javax.swing.GroupLayout.PREFERRED_SIZE,
								javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
				.addGap(27, 27, 27)
				.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING).addComponent(jLabel4)
						.addComponent(jcb_choose, javax.swing.GroupLayout.PREFERRED_SIZE,
								javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
				.addGap(34, 34, 34).addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
						.addComponent(jb_login).addComponent(jb_reset))
				.addContainerGap(34, Short.MAX_VALUE)));

		pack();
	}

	// 登录事件监控
	private void jb_loginActionPerformed(java.awt.event.ActionEvent evt) {
		String userName = userNameTxt.getText();
		String userPassword = new String(userPasswordTxt.getPassword());
		if (StringUtil.isEmpty(userName)) {
			JOptionPane.showMessageDialog(null, "用户名不能为空!");
			return;
		} else if (StringUtil.isEmpty(userPassword)) {
			JOptionPane.showMessageDialog(null, "密码不能为空!");
			return;
		}
		User user = new User(userName, userPassword);
		System.out.println("======xx===");
		Connection con = null;
		try {
			con = dmutil.getConnection();
			User currentuser = userdao.login(con, user);
			System.out.println("========="+currentuser);
			if (  null != currentuser) {
				User user1 = (User) jcb_choose.getSelectedItem();
				String userright = user1.getUsername();
				if (userright.equals("管理员")) {
					this.dispose();
					MainFrm main = new MainFrm();
					main.setVisible(true);
				} else if (userright.equals("学生")) {
					this.dispose();
					MainFrm2 main2 = new MainFrm2();
					main2.setVisible(true);
				} else {
					JOptionPane.showMessageDialog(null, "用户名密码错误!");
				}
			}else {
				JOptionPane.showMessageDialog(null, "用户名密码错误!");
			}
		} catch (Exception e) {
			JOptionPane.showInternalMessageDialog(null, "登陆失败");
			e.printStackTrace();
		}
	}

	// 重置事件监控
	private void jb_resetActionPerformed(java.awt.event.ActionEvent evt) {
		this.userNameTxt.setText("");
		this.userPasswordTxt.setText("");
	}

	private void userNameTxtActionPerformed(java.awt.event.ActionEvent evt) {
	}

	// 主函数
	public static void main(String args[]) {
		java.awt.EventQueue.invokeLater(new Runnable() {
			public void run() {
				new LoginFrm().setVisible(true);
			}
		});
	}

}






Room.java

package cn.com.model;

public class Room {
	String id;// 寝室号
	String member;// 成员
	String leader;// 寝室长

	// 构造函数
	public Room(String member) {
		super();
		this.member = member;
	}

	public Room() {
		super();
	}

	public Room(String id, String member, String leader) {
		super();
		this.id = id;
		this.member = member;
		this.leader = leader;
	}

	public Room(String member, String leader) {
		super();
		this.member = member;
		this.leader = leader;
	}

	// get,set方法
	public String getMember() {
		return member;
	}

	public void setMember(String member) {
		this.member = member;
	}

	public String getLeader() {
		return leader;
	}

	public void setLeader(String leader) {
		this.leader = leader;
	}

	public String getId() {
		return id;
	}

	public void setId(String id) {
		this.id = id;
	}

	public String toString() {
		return this.getMember();
	}

}


四、其他

获取源码

点击以下链接获取源码。

Java+Swing+Txt实现自助款机系统

Java+Swing+Mysql自助存取款机系统

Java+Swing+mysql5实现学生成绩管理系统(带分页)

Java+Swing+Mysql实现超市商品管理系统源码

Java+Swing+Mysql实现通讯录管理系统源码

Java+Swing+Mysql实现图书管理系统源码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/94613.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JQuery | 系统性学习 | 无知的我费曼笔记

无知的我已经复盘完成JQuery 。。。 文章目录JQuery概述入口函数特性-隐式迭代Dom和JQuery区别互相转化JQuery选择器基本和层级选择器筛选选择器后缀筛选方法筛选应用排他思想应用链式编程JQuery操作样式修改样式CSS修改类名JQuery效果基础效果显示效果隐藏效果切换效果滑动效果…

Springboot 使用redis检测浏览量,评论量,点赞量的变化并完成与mysql的交互(有具体实现,有具体需求)

目录 依赖 准备实体类与业务类 开始正题 实现一览 流程一览 具体实现 1 初始化 2 写浏览量增加的方法 3 在切面处检测浏览器变化 4 新增文章时将新的数据写入redis 5 删除文章时将数据从Redis中删除 6 书写将数据写入mysql数据库的方法 7 销毁的时候将数据写入my…

一文搞懂百万富翁问题

百万富翁问题1. 解决方案2. 协议描述3. 协议说明4. 协议举例两个百万富翁Alice和Bob想知道他们两个谁更富有,但他们都不想让对方及其他第三方知道自己财富的任何信息,这是由中国计算机科学家、2000年图灵奖获得者姚启智教授于1982年在论文《Protocols fo…

新手小白做跨境电商有哪些注意的地方?

近两年,受疫情刺激,线上电商出现前所未有的高速增长,中国品牌纷纷出海,跨境电商腾飞。此外,国内电商市场发展趋于平淡,市场需求不断萎缩,也让越来越多的大卖家和平台盯上了这块大蛋糕。不仅中小…

300左右半入耳蓝牙耳机推荐:南卡、漫步者、JBL蓝牙耳机谁值得入手?

现在的年轻人,出门都会随身携带的一副蓝牙耳机,所以很多品牌商加入其中,导致大多数人选购难度变大,很多人总是不知道哪个不知道品牌蓝牙耳机最好,半入耳式蓝牙耳机相比入耳式蓝牙耳机有着天然的舒适性,因而…

如何利用MOS管设计一个LED亮度可调电路

首先大家可以看下下面的MOS管亮度可调的演示视频 如何利用MOS管设计一个LED亮度可调电路这个电路大致电路图如下 MOS管的栅极放了一个电容,当按按键1的时候,电源通过R1给电容充电,,MOS管栅极的电压慢慢增大,流过MOS管的…

计算机毕业设计HTML+CSS+JavaScript——基于HTML花店购物网站项目的设计与实现

常见网页设计作业题材有 个人、 美食、 公司、 学校、 旅游、 电商、 宠物、 电器、 茶叶、 家居、 酒店、 舞蹈、 动漫、 服装、 体育、 化妆品、 物流、 环保、 书籍、 婚纱、 游戏、 节日、 戒烟、 电影、 摄影、 文化、 家乡、 鲜花、 礼品、 汽车、 其他等网页设计题目, A…

Essential singularity

In complex analysis, an essential singularity of a function is a “severe” singularity near which the function exhibits odd behavior. The category essential singularity is a “left-over” or default group of isolated singularities that are especially unm…

跳转指令 —— B、BL

跳转指令可以跳转到标号的下一条指令,本质就是修改了PC寄存器的值。(标号并非指令,只是用来定位,相当于记录了当前位置的下一条指令的地址) 这里的MAIN就是一个标号 MAIN: MOV R1, #1 这里的FUNC就是一个标…

实验3 路由器基本配置及路由配置

实验3 路由器基本配置及路由配置一、实验目的二、实验要求三、实验步骤,数据记录及处理四.实验总结一、实验目的 1、路由器几种模式。 2、基本的配置命令。 3、路由器各接口的配置方法。 4、会查看检测接口状态。 二、实验要求 写出自己学习使用了哪些…

Redis框架(十五):大众点评项目 共同关注方案实现?双指针筛选DB数据:Redis取交集

大众点评项目 好友关注 共同关注需求:好友关注 共同关注业务逻辑展示点击关注功能实现判断当前用户是否关注了此博主共同好友列表查询业务逻辑实现双指针筛选DB数据Redis取交集总结SpringCloud章节复习已经过去,新的章节Redis开始了,这个章节…

字节一面:select......for update会锁表还是锁行?

select查询语句是不会加锁的,但是select .......for update除了有查询的作用外,还会加锁呢,而且它是悲观锁。 那么它加的是行锁还是表锁,这就要看是不是用了索引/主键。 没用索引/主键的话就是表锁,否则就是是行锁。…

sklearn基础篇(十)-- 非负矩阵分解与t-SNE

1 非负矩阵分解(NFM) NMF(Non-negative matrix factorization),即对于任意给定的一个非负矩阵V\pmb{V}VVV,其能够寻找到一个非负矩阵W\pmb{W}WWW和一个非负矩阵H\pmb{H}HHH,满足条件VW∗H\pmb{VW*H}VW∗HVW∗HVW∗H,从而将一个非负的矩阵分解…

物联网架构实例—解决Linux(Ubuntu)服务器最大TCP连接数限制

1.前言: 在对物联网网关进行压测的时候,发现在腾讯云部署网关程序,设备接入数量只能达到4000多个长连接,之后就再也无法接入终端了。 之前在阿里云部署的时候明明可以到达2万左右,而且腾讯云的这个服务器比阿里云的硬…

蓝桥杯嵌入式综合实验真题-联网电压测量系统设计与实现

目录 实验要求: 实验思路: 核心代码: (1)变量声明 (2)函数声明 (3)main主函数 (4)按键(长按/短按) (5&…

K8s——Service、代理模式演示(二)

Service 演示 SVC 创建svc-deployment.yaml apiVersion: apps/v1 kind: Deployment metadata:name: myapp-deploynamespace: default spec:replicas: 3selector:matchLabels:app: myapprelease: stabeltemplate:metadata:labels:app: myapprelease: stabelenv: testspec: c…

学习UI设计有哪些figma插件

自2016年推出以来,Figma已发展成为市场领先者UI设计工具之一。 因为它不仅简单易用,功能优秀,而且基于云服务,可以实时编辑,节省大量手动下载或复制文件的时间。不仅如此,Figma还提供合作功能,…

一文读懂PFMEA(过程失效模式及后果分析)

PFMEA是过程失效模式及后果分析(Process Failure Mode andEffects Analysis)的英文简称,是由负责制造/装配的工程师/小组主要采用的一种分析技术,用以最大限度地保证各种潜在的失效模式及其相关的起因/机理已得到充分的考虑和论述。 名词解释&#xff1a…

springboot介绍

笔记来源于 动力节点springboot Javaconfig xml方式 在创建模块时&#xff0c;idea2022新版选择internal即可&#xff1a; pom.xml文件 <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xs…

圆顶光源特点及应用——塑料包装袋、PCB板检测

照明系统是机器视觉系统较为关键的部分之一&#xff0c;机器视觉光源直接影响到图像的质量&#xff0c;进而影响到系统的性能。其重要性无论如何强调都是不过分的。好的打光设计能够使我们得到一幅好的图象&#xff0c;从而改善整个整个系统的分辨率&#xff0c;简化软件的运算…