Java 数据库 课设 职工工资管理系(源代码)

Java 数据库课设 职工工资管理系(源代码)

一、要求

1.设计一个简单的职工工资管理系统,语言用Java swing SQLsever。
2.必须使用类、对象、异常处理、抽象类、接口、表格组件
3.需要创建界面,具有相应的按钮功能
4.要体现出继承和派生的特征

二、内容

1.管理员登录

2.添加职工信息

3.修改职工信息

4.查询职工信息

5.删除职工信息

6.添加职位信息

7.修改职位信息

8.查询职位信息

9.删除职位信息

10.添加部门信息

11.修改部门信息

12.查询部门信息

13.删除部门信息

三、E-R图

在这里插入图片描述
数据库
在这里插入图片描述

四、运行界面

代码太多,就只在这里展示一个登录界面代码,大家可以参考一下。

package payroll_system;


import java.awt.Color;
import java.awt.Font;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.ItemEvent;

import javax.swing.BorderFactory;
import javax.swing.ButtonGroup;
import javax.swing.Icon;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JPasswordField;
import javax.swing.JRadioButton;
import javax.swing.JTextField;

public class Login extends chouxiang implements image{
	JLabel l0,l1,l2,BK;//代表Swing中的标签组件,对象,表格组件
	JTextField t1;//文本框
	JPasswordField t2;//密码框
	JButton b1,b2;//按钮
	ButtonGroup b;//按钮组
	JPanel j1,j2;//面板
	String id="";
	JFrame frame=new JFrame();//frame界面
	
	public void Backgroundimage(){//重写抽象方法

		 ((JPanel) frame.getContentPane()).setOpaque(false);  
	     ImageIcon img = new ImageIcon("22.png"); // 添加图片  
	     BK = new JLabel(img);  
	     frame.getLayeredPane().add(BK, new Integer(Integer.MIN_VALUE));  
	     BK.setBounds(0, 0, 400, 330);
     
	}
	
	public static void main(String[] args) {
		//实例化image 命名为 testb 
		Login testb = new Login();
		testb.Backgroundimage();
		//是调用testb 中前面定义的Backgroundimage()方法
		
		Login login=new Login();
		login.face();
	}
	
	public void face() {
		setBackgroudImage();//图片会根据button的大小而改变 自动拉伸填充
		Backgroundimage();
		l0=new JLabel("闽南师范大学");

		
		l1=new JLabel("用户名");
		t1=new JTextField(50);
		l2=new JLabel("密码");
		t2=new JPasswordField(50);//设置密码窗口
		t2.setEchoChar('*');//使用‘*’隐藏密码
		
		
		//设置位置和大小
		l0.setBounds(150, 30, 400, 80);

		
		l1.setBounds(80, 95, 60, 40);
		l2.setBounds(80, 145, 60, 40);
		
		t1.setBounds(130, 100, 150, 30);
		t2.setBounds(130, 150, 150, 30);
		
		//设置'登录'及'注册'按钮
		b1=new JButton("登录");
		b1.setBounds(150, 200, 90, 30);
		//SetBt(b1);
		ButtonListener li0=new ButtonListener(t1,t2);
		//设置监听事件
		b1.addActionListener(li0);
		
		frame.setLayout(null);
		frame.add(l0);

		frame.add(l1);
		frame.add(l2);
		frame.add(t1);
		frame.add(t2);
		frame.add(b1);
		frame.setVisible(true);//设置窗口可见
		
		frame.setTitle("职工工资管理系统");
		frame.setSize(400,330);
		frame.setLocationRelativeTo(null);
		frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		frame.setVisible(true);
		frame.setResizable(false);
			
	}
	
	private void setBackgroudImage() {
		// TODO 自动生成的方法存根
		 ((JPanel) frame.getContentPane()).setOpaque(false);  
	        ImageIcon img = new ImageIcon("22.png"); // 添加图片  
	        BK = new JLabel(img);  
	        frame.getLayeredPane().add(BK, new Integer(Integer.MIN_VALUE));  
	        BK.setBounds(0, 0, 400, 330); 
	}
	
	//创建类实现接口
	public  class ButtonListener implements java.awt.event.ActionListener{    //实现ActionListener 接口 implement
	    JTextField te1=new JTextField();               //传参
		JPasswordField te2=new JPasswordField();                    //一个画板对象
		ButtonListener(JTextField te1,JPasswordField te2) {//重载 窗体上的账号框,密码框传到监听上来
			this.te1=te1;	
			this.te2=te2;
		}
		
		public ButtonListener(JTextField ID) {
			// TODO Auto-generated constructor stub
		}
	
	

		public void actionPerformed(ActionEvent ch) {
			// TODO Auto-generated method stub
			 if(ch.getActionCommand()=="登录"){
				// JOptionPane.showMessageDialog(null, "nb!");
				 Judge j = new Judge();
				 j.GuanJudge(te1,te2,frame);
			 }			
		}
	}

}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

我写的系统是比较简单的,如果有需要源代码参考的可以留言哈!也可以私信我,有时候看不到这里的消息,可能私聊就没回。

源代码可以点击这里下载

  • 21
    点赞
  • 195
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 80
    评论
"得分: " " " " " 课程设计报告 "企业工资管理系统 " " "XXX " "班级 "XXXXX " "学号 "XXXXXX " "课程名称 "数据库原理及应用 " "指导教师 " " 201X年X月X日 目 录 一.工资管理系统需求分析………………………………… 1.1功能需求………………………………………………… 1.1.1功能划分……………………………………… 1.1.2功能描述…………………………………………… 1.2性能需求………………………………………………… 1.3数据流图……………………………………………… 二.总体设计………………………………………………… 2.1数据库概念设计………………………………………… 2.2功能模块………………………………………………… 三.系统详细设计…………………………………………… 3.1数据库逻辑设计………………………………………… 3.2各模块功能……………………………………………… 3.2.1职工信息管理系统………………………………… 3.2.2职工工资管理系统………………………………… 3.2.3职工津贴管理系统………………………………… 四.系统实现………………………………………………… 4.1界面截图………………………………………………… 4.1.1主界面及工资基本信息界面…………………… 4.1.2登录界面………………………………………… 4.1.3系统主界面……………………………………… 4.1.4信息录入,修改,删除,查询界面………… 4.2设计代码………………………………………………… 五.实验总结………………………………………………… 1. 需求分析 1. 功能需求 1.1.1功能划分 (1)、员工信息表;及时反映员工的基本信息 (2)、员工津贴表,反映员工津贴 (3)、员工基本工资表 1.1.2 功能描述 (1)、基本工资的设定 (2)、津贴的设定 (3)、计算出月工资 (4)、录入员工工资信息 (5)、添加员工工资信息 (6)、更改员工工资信息 1.2性能需求 此工资管理系统对工资数据精度的计算能在默认情况之下精确到小数点后3位小数, 即是精确到分的计算。但在用户使用过程中,能自行根据实际情况进行小数计算精度的 设定,最大能允许保留小数点后5位的精度。在时间特性上,当用户发出命令请求时的服 务器的响应时间、对数据更新处理、工资数据的查询检索等上,同样要求系统响应时间 不会超过0.5秒时间。系统支持多种操作系统的运行环境,多不同操作系统,不同文件格 式的磁盘上的数据均能实现信息的互通,及共享。当服务器移植到其他的系统平台,如 :Linux平台下时,同样能和其他的系统进行数据存取同步,不会出现系统之间互不兼容 的情况,系统支持多系统之间的互连互通,系统有巨大的强健性。本课程设计是用Java 语言编写,mysql数据库。 1.3数据流图 根据工资管理要求及用户需求调查分析,得到以下数据流图 图1.1第一层数据流图 图1.2职工信息的载入 图1.4考勤的信息载入 2.总体设计 2.1数据库概念设计 有了数据流图,用E-R图来说明工资信息管理系统的数据库概念模式,如图 1 n m 图2.1实体之间关系E-R图 2.2功能模块 3.系统详细设计 3.1数据库逻辑设计 将以上E-R转换成如下关系模式 员工(职工号,,密码) 工资(职工号,,基本工资,) 津贴(职工号,,奖金) 其中,标有下划线的字段表示为该数据表的主码,即主关键字。在上面的实体以及实 体之间关系的基础上,形成数据库中的表格以及各个表格之间的关系。 工资信息管理系数据库中各个表格的设计结果如下面的几个表格所示。每个表格表 示在数据库中的一个表。 表一:员工信息表: "列名 "数据类型 "可否取空 "备注说明 " "no " Char ( 8 ) "NOT NULL "职工号(主键) " "name "Char(10) "NOT NULL "职工 " "mi "Smallint "NOT NULL "登录密码 " 表二:基本工资表: "列名 "数据类型 "可否取空 "备注说明 " "no "Char ( 8 ) "NOT NULL "职工号(主键) " "name "Char(10) "NOT NULL "职工 " "Jb "money "NOT NULL "基本工资 " 表四:津贴信息表 "列名 "数据类型 "可否为空 "备注说明 " "no "Char ( 8 ) "NOT NULL "职工号(主键) " "name "Char(10) "NOT NULL "职工 " "Jt "money "NOT NULL "津贴 " 3.2各模块功能 3.2.1职工信息管理系统 功能为:财务部门相关
.2.2 职工需求描述 对于职工来说,职工可以修改其密码信息,查询其基本信息和工资信息,收发留言信息。 职工登陆 职工在登陆时输入自己的用户名和密码,如无误后进入职工信息中心界面。默认的密码由管理员分配。如果密码错误则提示密码出错请重新输入,职工可以返回登陆界面。 职工密码修改 职工在登陆后,可以修改自己的密码。在修改密码界面中,需要两次输入自己的新密码,然后系统经过判断修改密码。下次可以通过新密码登陆系统。 职工考勤信息查询 在职工登陆后,进入考勤查询界面,页面给出每月的考勤信息,点击相应的年月,可以查看自己每个月的考勤记录详细信息。 职工工资信息查询 进入查询界面,职工可以查看详细工资情况,职工可以通过选择月份,便可以查询职工固定月份的工资信息。职工还可以查询自己的奖惩信息。 职工留言管理 职工可以向管理员发送留言,查看管理员发送给自己的留言。 3.2.3 管理员需求描述 对于管理员来说,管理员的能够实现的功能是该工资管理系统的核心功能,包括员工基本档案信息的管理,工资的设定与计算,考勤记录与统计,奖惩或其他重要事项的记录,留言管理,科室信息管理等。 管理员登陆 管理员在登陆框选择身份为管理员,输入自己的管理员号以及密码。如无误后进入管理员界面。如果密码不正确则提示密码错误信息,需要重新输入,返回管理员登陆界面。 密码修改 管理员可以修改自己的密码,下次登陆时管理员就需要输入自己的新密码登陆系统。 科室管理 随着医院规模的扩大,医院可能需要增加某些科室,修改科室信息等,管理员登陆系统后,可以对科室信息进行管理、操作。 员工信息管理 管理员登陆后,可以进行查看员工信息,增加员工,修改员工信息,删除员工信息等操作。 员工奖惩信息管理 根据 人民医院管理制度,管理员可以使用系统记录每个员工的奖励 ,惩罚等其他重要信息,以便确定员工的工作状况,实现相应的奖励和处罚。 员工工资设置 管理员登陆系统后,可以设置每个员工的每月工资信息,其中工资项包括基本工资,基本津贴,财务人员需要为每个在职的员工设定基本工资与基本津贴。财务人员根据员工的具体工资情况,输入奖金,税率等,系统自动计算应发,扣发,实发等工资项。 工资统计与报表打印 统计每个月所有员工的工资信息,并提供报表打印功能。 留言管理模块 职工查看自己的工资信息后,如有问题,可以向财务人员(系统管理员)发送留言,管理员可以回复留言,删除留言信息。
图书管理系统是一个常见的数据库应用程序,使用Java作为前端编程语言连接MySQL数据库进行数据管理和操作。 首先,我将使用Java提供的JDBC(Java Database Connectivity)API来连接MySQL数据库。通过使用JDBC驱动程序,我可以在Java应用程序中建立与MySQL数据库的连接,并操作数据库中的数据。 接下来,我将创建一个图书管理系统的数据库模式,包括图书、借阅者和借阅记录等表。每个表将包含必要的字段,例如图书表将有图书编号、书名、作者等字段。 在Java代码中,我将编写适当的SQL语句来创建表和插入数据。这些SQL语句将使用JDBC API中的Statement或PreparedStatement对象执行。例如,我可以使用CREATE TABLE语句来创建图书表,使用INSERT INTO语句来向图书表中插入图书数据。 然后,我将实现图书管理系统的各种功能,例如添加图书、删除图书、借书、还书等。这些功能将通过执行相应的SQL语句来实现。例如,当用户想要借书时,我将执行UPDATE语句将图书表中的借书状态改为已借,并向借阅记录表中插入一条借阅记录。 此外,我将使用Java Swing来实现一个用户友好的界面,用户可以通过界面与系统进行交互。例如,用户可以通过点击按钮或输入文本框来执行相应的功能,如添加图书或查询借阅记录。 最后,我将使用异常处理机制来处理潜在的错误和异常情况,例如数据库连接失败、SQL语句执行错误等。通过捕获和处理这些异常,我可以向用户提供有用的错误提示信息,并确保系统的稳定性和可靠性。 总而言之,通过使用Java连接MySQL数据库,我将实现一个功能完善的图书管理系统,帮助用户进行图书的管理和借阅操作。这个系统将提供一个简单而强大的界面,并通过合理的数据库设计和有效的Java编码来确保数据的管理和操作的准确性和一致性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 80
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

leslieyhh

让我们一起从小白走向大佬吧!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值