员工工资管理系统(VB+SQL)_第1页
员工工资管理系统(VB+SQL)_第2页
员工工资管理系统(VB+SQL)_第3页
员工工资管理系统(VB+SQL)_第4页
员工工资管理系统(VB+SQL)_第5页
已阅读5页,还剩25页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

VB+SQLserve2000课程设计报告员工工资管理系统姓名:_________班级:________________学号:____________指导教师:____成绩:_____________________完成时间:2023-12-28完成地点:蚌埠学院TOC\o"1-3"\h\u19359摘要 14783第一章绪论 2118141.1数据库管理系统 253101.2员工工资管理系统 2218031.3开发工具 36580第二章员工工资管理系统设计分析 3213412.1应用需求与分析 316682.2系统模块划分 3109712.3系统数据库设计 410725第三章:企业工资管理系统应用程序设计 5144083.1操作流程图 5152483.2“登录模块〞详细设计 6295863.3“主窗体〞模块详细设计 10241713.4各项子模块详细设计 1371563.4.1添加用户与删除 1312873.4.2修改用户 15207283.4.3数据库备份和恢复 17212743.4.4退出 20267493.4.5根本工资 20112423.4.6岗位工资 2246303.4.7部门管理 24237273.4.8员工管理 2667143.4.9发放工资 2729463.4.10按员工查询 32297283.4.11按部门查询 335718模块一: 3510037模块二: 3511010第五章:结束语 3626001谢辞 3726736参考文献: 37摘要企业的工资管理是公司管理的一个重要内容。随着企业人员数量增加,企业的工资管理工作也变得越来越复杂。工资管理既涉及到企业劳动人事的管理,同时也是企业财务管理的重要组成局部。工资管理需要和人事管理相联系,同时连接工时考勤和医疗保险等等,来生成企业每个职工的根本工资、津贴、医疗保险、保险费、实际发放工资等。资金是企业生存的主要元素,资金的流动影响到企业的整体运作,企业员工的工资是企业资金管理的一个重要的组成局部。早期的工资统计和发放都是使用人工方式处理纸质材料,不仅花费财务人员大量的时间且不易保存,往往由于个人的因素抄写不慎或计算疏忽,出现工资发放错误的现象。早期工资管理多采取纸质材料和具有较强的时间限制。基于以上原因,企业工资管理系统使用电脑平安保存、快速计算、全面统计,实现工资管理的系统化、标准化、自动化。企业工资管理系统是典型的信息管理系统〔MIS〕,前台程序开发工具采用微软的VB6,后台数据库采用sqlserve2000数据库。VB6是一种面向对象的开发工具,具有组件丰富、语言简单、功能强大的优点。sqlserve2000数据库具有与VB6无缝连接、操作简单、易于使用的优点。运行结果证明,本企业工资管理系统极大提高了工作效率,节省了人力和物力,最终满足企业财务管理、员工工资发放的需要,同时也成为现代化企业管理的标志。第一章绪论1.1数据库管理系统数据库管理系统〔DBMS〕是指数据库系统中管理数据的软件系统。DBMS是数据库系统的核心组成局部。对数据库的一切操作,包括定义、更新及各种控制,都是通过DBMS进行的。DBMS总是基于某种数据模型,可以把DBMS看成是某种数据模型在计算机系统上的具体实现。根据数据模型的不同,DBMS可以分成层次型、网状型、关系型、面向对象型等。MSsqlserve2000就是一种关系型数据库管理系统。关系模型主要是用二维表格结构表达实体集,用外键表示实体间联系。关系模型是由假设干个关系模式组成的集合。关系模式相当于前面提到的记录类型,每个关系实际上是一张二维表格。关系模型和层次、网状模型的最大判别是用关键码而不是用指针导航数据,表格简单用户易懂,编程时并不涉及存储结构,访问技术等细节。SQL语言是关系型数据库的标准化语言,已得到了广泛的应用。1.2员工工资管理系统企业工资管理是一项琐碎、复杂而又十分细致的工作,一般不允许发生过失。最初的工资统计和发放都是使用人工方式处理,工作量大的时候,出现错误的机率也随之升高,不仅花费财务人员大量的时间,而且往往由于抄写不慎,或者由于计算的疏忽,出现工资发放错误的现象。同时工资的发放具有较强的时间限制,必须严格按照单位规定的时间完成计算和发放工作。正是企业工资管理的这种重复性、规律性、时间性,使得企业工资管理计算机化成为可能。企业工资管理系统就是使用电脑代替大量的人工统计和计算,完成众多企业工资信息的处理,同时使用电脑还可以平安地、完整地保存大量的企业工资记录。1.3开发工具微软公司的VisualBasic6.0是Windows应用程序开发工具,是目前最为广泛的、易学易用的面向对象的开发工具。VisualBasic提供了大量的控件,这些控件可用于设计界面和实现各种功能,减少了编程人员的工作量,也简化了界面设计过程,从而有效的提高了应用程序的运行效率和可靠性。因此,本系统使用MSVisualBasic6.0开发。第二章员工工资管理系统设计分析2.1应用需求与分析根本信息的添加、修改、删除和查询。根本信息包括工程类型信息,工程状态信息,模块状态信息和缺陷级别信息等。此功能为工程组管理和软件工程管理模块提供数据。工程组信息的添加、修改、删除和查询。工程组信息包括收员工信息和角色信息。软件工程管理模块包括工程根本信息管理、软件模块管理和软件缺陷管理等功能2.2系统模块划分开发这个系统的目的就是帮助企业的财务主管部门提高工作效率,实现企业工资信息管理的系统化、标准化和自动化。能够和认识管理系统、考勤管理系统相结合,真正实现企业高效、科学、现代化的员工管理。系统最终实现的主要功能如下。·企业工资信息设置局部:包括设置员工的根本工资和其他工程的金额,如奖金等。·企业工资信息管理局部:包括统计出勤、计算工资、查询工资和导出工资表。·系统局部:包括添加用户和修改密码。2.3系统数据库设计数据库是信息管理系统的后台,存储着所有的信息,在信息管理系统中有着很重要的地位。数据库设计的好与坏,直接影响到这个系统的运行效率。良好的数据库设计,可以提高数据信息的存储效率,确保数据信息的完整性和一致性。针对企业工资信息管理系统的需求,通过对员工工资计算过程的内容分析,为本系统设计如下的数据项和数据结构:·根本工资信息:包括工资级别和工资金额。·岗位工资信息:包括工资级别和工资金额。·工资信息:包括员工编号、根本工资、岗位工资、水电费、实发金额。·部门信息:包括部门编号、部门名称、部门负责人、部门人数。·工资统计信息:包括员工编号、姓名、出生年月、所属部门、文化程度、职称。·用户信息:包括用户名、密码和权限。员工信息表员工编号char(8)主键,不允许重复姓名char(8)性别char(2)出生年月datetime所属部门char(4)外键文化程度char(4)职称char(12)部门信息部门编号char(4)主键,不允许重复部门名称char(20)部门负责人char(8)部门人数int根本工资工资级别char(2)主键,不允许重复工资金额numeric(8,2)岗位工资工资级别char(2)主键,不允许重复工资金额numeric(8,2)工资信息员工编号char(8)主键,不允许重复;外键根本工资numeric(8,2)岗位工资numeric(8,2)水电费numeric(8,2)实发金额numeric(8,2)用户表用户名char(8)主键,不允许重复密码char(20)权限char(20)E-R图:第三章:企业工资管理系统应用程序设计3.1操作流程图初始登入用户:admin密码为:admin用户登入用户登入录入口令是否正确?进入工资管理主界面职员管理工资工程/工资数据录入/工资报表用户管理数据备份/恢复结束当月工资3.2“登录模块〞详细设计登录模块的详细设计主要是用户登录的一个界面,判断登录的用户是管理员还是普通用户,进入后将面对的是主界面,从而进行相关的操作。登录的界面主要由用户名和密码的信息,还有一些标题设置,确定和取消的按钮组成。通过标题可以知道此系统的大概内容,由此,登录界面的设计完成。窗体及核心代码:PrivateSubcmd_cancel_Click()txt_key.Text=""cmo_user.Text="请选择"UnloadMeEndSubPrivateSubcmd_ok_Click()Dimtry_timesAsStringDimsqlAsStringDimrstAsADODB.Recordsettry_times=0If(Trim(txt_key.Text)="")ThenMsgBox"请输入密码",vbOKOnly+vbExclamation,"提示"Elsesql="select*from用户表where用户名='"&Trim(cmo_user.Text)&"'"Setrst=ExecuteSQL(sql,"")IfTrim(rst.Fields(1))=Trim(txt_key.Text)ThenIfTrim(rst.Fields(2))<>"管理员"Thenfrm_main.xitong.Enabled=False'在这里设计非管理员用户的权限,这里我假设让非管理员用户不能用菜单中的‘系统’frm_main.shezhi.Enabled=Falsefrm_main.xinxiweihu.Enabled=FalseEndIfrst.CloseUserName=Trim(cmo_user.Text)frm_main.ShowUnloadMeElseMsgBox"密码不正确,请重新输入",vbOKOnly+vbExclamation,"警告"txt_key.SetFocustxt_key.Text=""try_times=try_times+1ExitSub'在这里假设密码错了应该跳出该过程,否那么下面的语句还会执行,这不是你想要的EndIf'try_times=try_times+1'个人认为密码输入错了才加一,你这样的话,用户名错了也会加一,当然你这里用户名不会错是吧,改得多余了Iftry_times=3ThenUnloadMeEndIfEndIfEndSubPrivateSubForm_Load()DimiAsIntegerDimsqlAsStringDimrstAsADODB.Recordsetsql="select用户名from用户表"Setrst=ExecuteSQL(sql,"")Fori=1Torst.RecordCountcmo_user.AddItem(rst.Fields(0))rst.MoveNextNextiEndSub主窗体:PrivateSubbumenxinxi_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_bumenxinxi.ShowUnloadMeEndIfEndIfEndSubPrivateSubgangweigongzi_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_gangweigongzi.ShowUnloadMeEndIfEndIfEndSubPrivateSubjiben_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_jiben.ShowUnloadMeEndIfEndIfEndSubPrivateSubyonghushanchu_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_tianjiayushanchu.ShowUnloadMeEndIfEndIfEndSubPrivateSubyonghutianjia_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_tianjiayushanchu.ShowUnloadMeEndIfEndIfEndSubPrivateSubForm_Load()DimiAsIntegerDimsqlAsStringDimrstAsADODB.Recordsetsql="select权限from用户表"Setrst=ExecuteSQL(sql,"")Fori=1Torst.RecordCountrst.MoveNextNexti3.3“主窗体〞模块详细设计在这个工程中,选择使用多文档界面。使用这个窗体的好处是可以使程序更加有条理。对于一个多任务的应用程序,使用多文档窗体还可以减少占用的系统资源。主窗体设计的界面是用菜单编辑器做的,主要由系统、工资信息设置、工资信息管理和关于这四个大模块组成。主窗体是进行相关操作的主界面。在这几个里,管理员有所有的权利进行各种操作。主窗体及核心代码:PrivateSubbumenxinxi_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_bumenxinxi.ShowUnloadMeEndIfEndIfEndSubPrivateSubgangweigongzi_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_gangweigongzi.ShowUnloadMeEndIfEndIfEndSubPrivateSubjiben_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_jiben.ShowUnloadMeEndIfEndIfEndSubPrivateSubyonghushanchu_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_tianjiayushanchu.ShowUnloadMeEndIfEndIfEndSubPrivateSubyonghutianjia_Click()DimsqlAsStringDimrstAsNewADODB.Recordsetsql="select*from用户表"Setrst=ExecuteSQL(sql,"")power=rst.Fields(2)IfTrim(power)<>"管理员"ThenMsgBox"您无权进行该操作!",vbOKOnly+vbExclamation,"警告"ElseIfTrim(power)="管理员"Thenfrm_tianjiayushanchu.ShowUnloadMeEndIfEndIfEndSubPrivateSubForm_Load()DimiAsIntegerDimsqlAsStringDimrstAsADODB.Recordsetsql="select权限from用户表"Setrst=ExecuteSQL(sql,"")Fori=1Torst.RecordCountrst.MoveNextNextiEndSub3.4各项子模块详细设计3.4.1添加用户与删除选择“系统〞—>“添加用户与删除〞菜单,在添加用户的窗体里,输入新的用户名称和密码后,单击“添加〞按钮,系统将会添加新的用户。在窗体里输入用户名称和密码,单击“删除〞按钮,系统将会删除原来用户。PrivateSubcmd_adduser_Click()DimnewrstAsADODB.RecordsetDimsqlAsStringsql="insertinto用户表values("&"'"&Trim(txt_username.Text)&"',"_&"'"&Trim(txt_password.Text)&"',"_&"'"&Trim(txt_power)&"'"&")"Setnewrst=execute_sql(sql)sql="select*from用户表"Setnewrst=select_sql(sql)SetDataGrid1.DataSource=newrstEndSubPrivateSubcmd_cancel_Click()UnloadMeEndSubPrivateSubcmd_delete_Click()DimsqlAsStringsql="select*from用户表"Iftxt_username<>""ThenSetobjrs=ExecuteSQL(sql,"")SetDataGrid1.DataSource=objrs'刷新网格,显示操作后的结果EndIfIfobjrs.RecordCount=0ThenMsgBox"库中没有记录!"ExitSubEndIfIfobjrs.RecordCount<>0ThenIfMsgBox("真的要删除该级用户信息吗?",vbYesNo+vbQuestion,"警告")=vbYesThenobjrs.DeleteMsgBox"删除成功!",vbInformation,"提示"EndIfEndIfEndSubPrivateSubForm_Load()DimnewrstAsADODB.RecordsetDimsqlAsStringsql="select*from用户表"Setnewrst=select_sql(sql)SetDataGrid1.DataSource=newrstEndSub3.4.2修改用户选择“系统〞->“修改用户〞菜单,在窗体里输入新的用户名称和用户权限,单击“修改〞按钮,系统将会修改原来用户信息。PrivateSubcmd_adduser_Click()DimnewrstAsADODB.RecordsetDimsqlAsStringsql="insertinto用户表values("&"'"&Trim(txt_username.Text)&"',"_&"'"&Trim(txt_password.Text)&"',"_&"'"&Trim(txt_power)&"'"&")"Setnewrst=execute_sql(sql)sql="select*from用户表"Setnewrst=select_sql(sql)SetDataGrid1.DataSource=newrstEndSubPrivateSubcmd_cancel_Click()UnloadMeEndSubPrivateSubcmd_delete_Click()DimsqlAsStringsql="select*from用户表"Iftxt_username<>""ThenSetobjrs=ExecuteSQL(sql,"")SetDataGrid1.DataSource=objrs'刷新网格,显示操作后的结果EndIfIfobjrs.RecordCount=0ThenMsgBox"库中没有记录!"ExitSubEndIfIfobjrs.RecordCount<>0ThenIfMsgBox("真的要删除该级用户信息吗?",vbYesNo+vbQuestion,"警告")=vbYesThenobjrs.DeleteMsgBox"删除成功!",vbInformation,"提示"EndIfEndIfEndSubPrivateSubForm_Load()DimnewrstAsADODB.RecordsetDimsqlAsStringsql="select*from用户表"Setnewrst=select_sql(sql)SetDataGrid1.DataSource=newrstEndSub3.4.3数据库备份和恢复选择“系统〞->“数据库备份和恢复〞菜单,在位置文本框中输入备份或恢复的文件所在位置,单击“备份〞或“恢复〞按钮,数据库将备份或恢复。OptionExplicitPrivateSubcmd_recovery_Click()IfcnMod.State=adStateOpenThencnMod.Close'如果已连接,关掉宽EndIfcnMod.Open"driver={sqlserver};server=HZ;uid=sa;pwd=heweiling;database=master"'建一个连接用来获得要复原数据库的进程标识符〔spid〕DimrsAsNewADODB.Recordset'该记录集保存进程ID以备操作rs.Open"selectspidfromsysprocesseswheredbid=db_id('工资管理系统')",cnMod,adOpenDynamic,adLockPessimistic'解释一下,这句话是为了将有关“工资管理系统〞所有效劳进程ID查询出来db_id是SQL中的一个函数具体语法你自己看它的帮助文件哦,这里就不赘述了Ifrs.EOF=FalseThenrs.MoveFirstDoWhilers.EOF=True'扫描并关闭有关“工资管理系统〞的效劳进程cnMod.Execute("kill"&rs.Fields(0))'kill也是SQL的方法“杀〞与dos下的kill类似啊,是吧,呵呵自己看看帮助文件很详尽的rs.MoveNextLoopEndIfCD.Filter="所有文件〔*.*〕|*.*|备份文件(*.bak)|*.bak"CD.InitDir=App.PathText1.Text=CD.FileNameCD.ShowOpenDimMstrAsStringMstr="恢复主要数据库?数据恢复操作将会覆盖以前的所有数据并且覆盖后无法恢复,您确定要进行恢复操作吗?"IfMsgBox(Mstr,vbYesNo+vbQuestion,"操作提示")=vbYesThenOnErrorGoToreLabel1.Caption="正在恢复,请稍候……"cnMod.BeginTrans'开始一个事件cnMod.Execute("restoredatabase工资管理系统fromdisk='"&CD.FileName&"'withreplace")'SQL语句要是不会用,查看帮助文件cnMod.CommitTrans'执行Label1.Caption="恢复成功"MsgBox"恢复成功",vbOKOnly+vbInformation,"提示"ExitSubre:cnMod.RollbackTrans'回滚〔不执行〕Label1.Caption="恢复失败"MsgBox"恢复失败",vbOKOnly+vbInformation,"提示"EndIfEndSubPrivateSubcmd_back_Click()'下面是备份的代码,处理的比拟粗糙,你自己优化了,呵呵,相信你能看懂的,我就不注释了IfcnMod.State=adStateOpenThencnMod.CloseEndIfCD.Filter="所有文件〔*.*〕|*.*|备份文件(*.bak)|*.bak"CD.InitDir=App.PathCD.ShowSavetxt_weizhi=CD.FileNamecnMod.Open"driver={sqlserver};server=HZ;uid=sa;pwd=heweiling;database=工资管理系统"OnErrorGoTobackcnMod.BeginTranscnMod.Execute("backupdatabase工资管理系统todisk='"&CD.FileName&"'")cnMod.CommitTransMsgBox"成功地备份到"&CD.FileName&"下",vbOKOnly+vbInformation,"操作提示"cnMod.CloseExitSubback:cnMod.RollbackTransMsgBox"备份失败",vbOKOnly+vbInformation,"提示"cnMod.CloseEndSub'到这里就告一段落了,是不是很简单呢,当然这里有很多缺乏,你自己完善吧PrivateSubForm_Load()EndSub3.4.4退出选择“系统〞->“退出〞菜单,单击那么推出主菜单界面。3.4.5根本工资选择“设置〞->“根本工资〞菜单,可以单击“添加〞,“删除〞,“修改〞,“取消〞按钮来实现相应功能。DimobjrsAsADODB.RecordsetDimmsg_sqlAsStringPrivateSubcmd_add_Click()IfCombo_level.Text<>""ThenSetobjrs=ExecuteSQL("insertinto根本工资values("+Str(Combo_level.Text)+","+(Text_pay.Text)+")",msg_sql)'插入符合条件的工资信息Setobjrs=ExecuteSQL("select*from根本工资",msg_sql)SetDataGrid1.DataSource=objrs'刷新网格,显示操作后的结果Combo_level.SetFocusCombo_level.Text=""Text_pay.Text=""EndIfEndSubPrivateSubcmd_cancel_Click()UnloadMeEndSubPrivateSubcmd_delete_Click()Ifobjrs.RecordCount=0ThenMsgBox"库中没有记录!"ExitSubEndIfIfobjrs.RecordCount<>0ThenIfMsgBox("真的要删除该级别工资信息吗?",vbYesNo+vbQuestion,"警告")=vbYesThenobjrs.DeleteMsgBox"删除成功!",vbInformation,"提示"Combo_level.SetFocusCombo_level.Text=""Text_pay.Text=""EndIfEndIfEndSubPrivateSubForm_Load()Setobjrs=ExecuteSQL("select*from根本工资",msg_sql)SetDataGrid1.DataSource=objrsEndSubPrivateSubText_pay_LostFocus()IfVal(Text_pay.Text)<0OrVal(Text_pay.Text)>=10000ThenMsgBox"数据非法"Text_pay.Text=""Text_pay.SetFocusEndIfEndSub3.4.6岗位工资选择“设置〞->“岗位工资〞菜单,可以单击“添加〞,“删除〞,“修改〞,“取消〞按钮来实现相应功能。DimobjrsAsADODB.RecordsetDimmsg_sqlAsStringPrivateSubcmd_add_Click()IfCombo_level.Text<>""ThenSetobjrs=ExecuteSQL("insertinto岗位工资values("+Str(Combo_level.Text)+","+(Text_pay.Text)+")",msg_sql)'插入符合条件的工资信息Setobjrs=ExecuteSQL("select*from岗位工资",msg_sql)SetDataGrid1.DataSource=objrs'刷新网格,显示操作后的结果Combo_level.SetFocusCombo_level.Text=""Text_pay.Text=""EndIfEndSubPrivateSubcmd_cancel_Click()UnloadMeEndSubPrivateSubcmd_delete_Click()Ifobjrs.RecordCount=0ThenMsgBox"库中没有记录!"ExitSubEndIfIfobjrs.RecordCount<>0ThenIfMsgBox("真的要删除该级别工资信息吗?",vbYesNo+vbQuestion,"警告")=vbYesThenobjrs.DeleteMsgBox"删除成功!",vbInformation,"提示"Combo_level.SetFocusCombo_level.Text=""Text_pay.Text=""EndIfEndIfEndSubPrivateSubForm_Load()Setobjrs=ExecuteSQL("select*from岗位工资",msg_sql)SetDataGrid1.DataSource=objrsEndSubPrivateSubText_pay_LostFocus()IfVal(Text_pay.Text)<0OrVal(Text_pay.Text)>=10000ThenMsgBox"数据非法"Text_pay.Text=""Text_pay.SetFocusEndIfEndSub3.4.7部门管理选择“信息维护〞->“部门管理〞菜单,可以单击“添加〞,“删除〞,“修改〞,“取消〞按钮来实现相应功能。DimobjrsAsADODB.RecordsetDimmsg_sqlAsStringPrivateSubcmd_add_Click()Dimsqlbianhao,sqlmingcheng,sqlfuzeren,sqlrenshuAsStringsqlbianhao=cmo_bianhao.Textsqlmingcheng=cmo_mingcheng.Textsqlfuzeren=txt_fuzeren.Textsqlrenshu=txt_renshu.TextIfcmo_bianhao.Text<>""Andcmo_mingcheng.Text<>""ThenIfMsgBox("确定添加吗?",vbYesNo+vbExclamation,"警告")=vbYesThenSetobjrs=ExecuteSQL("insertinto部门信息values("+"'"+sqlbianhao+"'"+",'"+sqlmingcheng+"','"+sqlfuzeren+"','"+sqlrenshu+"')",msg_sql)Setobjrs=ExecuteSQL("select*from部门信息",msg_sql)SetDataGrid1.DataSource=objrsMsgBox"添加成功!",vbOKOnly+vbExclamation,"警告"EndIfEndIfEndSubPrivateSubcmd_alter_Click()IfTrim(cmo_bianhao.Text)=""OrTrim(cmo_mingcheng.Text)=""OrTrim(txt_fuzeren.Text)=""OrTrim(txt_renshu.Text)=""ThenMsgBox"请将修改后的信息填写完整!",vbOKOnly+vbExclamation,"警告"ElseIfMsgBox("确定修改吗?",vbYesNo+vbExclamation,"警告")=vbYesThenSetrst=ExecuteSQL("update部门信息set部门名称='"&Trim(cmo_mingcheng.Text)&"'where部门编号='"&Trim(cmo_bianhao.Text)&"'",msg_sql)Setrst=ExecuteSQL("update部门信息set部门负责人='"&Trim(txt_fuzeren.Text)&"'where部门编号='"&Trim(cmo_bianhao.Text)&"'",msg_sql)Setrst=ExecuteSQL("update部门信息set部门人数='"&Trim(txt_renshu.Text)&"'where部门编号='"&Trim(cmo_bianhao.Text)&"'",msg_sql)Setrst=ExecuteSQL("select*from基部门信息",msg_sql)SetDataGrid1.DataSource=objrsMsgBox"修改成功!",vbOKOnly+vbExclamation,"警告"cmo_bianhao.SetFocuscmo_bianhao.Text=""cmo_mingcheng.Text=""txt_fuzeren.Text=""txt_renshu.Text=""EndIfEndIfEndSubPrivateSubcmd_cancel_Click()frm_main.ShowUnloadMeEndSubPrivateSubcmd_delete_Click()Ifobjrs.RecordCount=0ThenMsgBox"库中没有记录!"ElseIfobjrs.RecordCount<>0ThenIfMsgBox("真的要删除该部门?",vbYesNo+vbQuestion,"警告")=vbYesThenobjrs.DeleteMsgBox"删除成功!",vbInformation,"提示"EndIfEndIfEndIfEndSubPrivateSubForm_Load()Setobjrs=ExecuteSQL("select*from部门信息",msg_sql)SetDataGrid1.DataSource=objrsEndSub3.4.8员工管理选择“信息维护〞->“员工管理〞菜单,可以单击“添加〞,“删除〞,“修改〞,“取消〞按钮来实现相应功能。3.4.9发放工资选择“信息维护〞->“发放工资〞菜单,单击“添加〞或“修改〞按钮那么弹出“添加员工工资〞菜单,单击“添加〞或“修改〞那么可以实现添加员工工资或者修改员工工资。DimrstAsADODB.RecordsetDimsqlAsStringPrivateSubcmd_add_Click()frm_tianjiagongzi.ShowEndSubPrivateSubcmd_alter_Click()frm_tianjiagongzi.Show'txt_no.Enabled=Falsefrm_tianjiagongzi.Showfrm_tianjiagongzi.txt_bianhao.Text=DataGrid1.Columns(0)'frm_addsalary.txt_name=DataGrid1.Columns(1)frm_tianjiagongzio_jiben=DataGrid1.Columns(1)frm_tianjiagongzio_gangwei=DataGrid1.Columns(2)frm_tianjiagongzi.txt_shuidian=DataGrid1.Columns(3)EndSubPrivateSubcmd_delete_Click()Ifrst.RecordCount<>0ThenIfMsgBox("确定删除该员工的工资信息吗?",vbYesNo+vbQuestion,"警告")=vbYesThenrst.DeleteSetrst=ExecuteSQL("select*from工资信息",sql)SetDataGrid1.DataSource=rstMsgBox"删除成功!",vbOKOnly+vbExclamation,"提示"EndIfEndIfEndSubPrivateSubcmd_cancel_Click()frm_main.ShowUnloadMeEndSubPrivateSubForm_Load()Setrst=ExecuteSQL("select*from工资信息",sql)SetDataGrid1.DataSource=rstEndSubDimrstAsADODB.RecordsetDimmsg_sqlAsStringDimjiben,gangwei,salaryAsDoubleDimaddsalarysqlAsStringPrivateSubcmd_alter_Click()DimupdatesqlAsStringtxt_bianhao.Enabled=FalseSetrst=ExecuteSQL("select*from员工信息where员工编号='"&Trim(txt_bianhao.Text)&"'",msg_sql)txt_xingming.Text=rst.Fields(0)Ifrst.RecordCount=0ThenMsgBox"请将修改后的信息填写完整!",vbOKOnly+vbExclamation,"警告"ElseIfrst.RecordCount<>0ThenIfMsgBox("确定修改吗?",vbYesNo+vbExclamation,"警告")=vbYesThenSetrst=ExecuteSQL("select*from根本工资where工资级别='"&Trim(cmo_jiben.Text)&"'",msg_sql)jiben=rst.Fields(1)Setrst=ExecuteSQL("select*from岗位工资where工资级别='"&Trim(cmo_gangwei.Text)&"'",msg_sql)gangwei=rst.Fields(1)salary=jiben+gangwei-Trim(txt_shuidian.Text)updatesql="update工资信息set根本工资="&jiben&","&"岗位工资="&gangwei&","&"水电费="&"'"&Trim(txt_shuidian.Text)&"'"&","&"实发金额="&salary&"where员工编号='"&Trim(txt_bianhao.Text)&"'"Setrst=ExecuteSQL(updatesql,msg_sql)MsgBox"修改成功!",vbOKOnly+vbExclamation,"警告"UnloadMeSetrst=ExecuteSQL("select*from工资信息",msg_sql)Setfrm_fafanggongzi.DataGrid1.DataSource=rsttxt_bianhao.Text=""txt_xingming.Text=""cmo_jiben.Text=""cmo_gangwei.Text=""txt_shuidian.Text=""EndIfEndIfEndIfEndSubPrivateSubcmd_cancel_Click()UnloadMeEndSubPrivateSubcmd_ok_Click()Setrst=ExecuteSQL("select*from根本工资",msg_sql)Ifrst.RecordCount=0ThenMsgBox"请先录入根本工资信息"ElseIfrst.RecordCount=0ThenMsgBox"请先录入岗位工资信息"ElseSetrst=ExecuteSQL("select*from根本工资where工资级别='"&Trim(cmo_jiben.Text)&"'",msg_sql)jiben=rst.Fields(1)Setrst=ExecuteSQL("select*from岗位工资where工资级别='"&Trim(cmo_gangwei.Text)&"'",msg_sql)gangwei=rst.Fields(1)salary=jiben+gangwei-Trim(txt_shuidian.Text)addsalarysql="insertinto工资信息values('"&Trim(txt_bianhao.Text)&"','"&jiben&"','"&gangwei&"','"&Trim(txt_shuidian.Text)&"','"&salary&"')"Setrst=ExecuteSQL(addsalarysql,msg_sql)UnloadMeSetrst=ExecuteSQL("select*from工资信息",msg_sql)Setfrm_salary.DataGrid1.DataSource=rstEndIfEndIfEndSubPrivateSubForm_Load()Setrst=ExecuteSQL("select*from根本工资",msg_sql)Fori=1Torst.RecordCountcmo_jiben.AddItem(rst.Fields(0))rst.MoveNextNextiSetrst=ExecuteSQL("select*from岗位工资",msg_sql)Fori=1Torst.RecordCountcmo_gangwei.AddItem(rst.Fields(0))rst.MoveNextNextiEndSubPrivateSubtxt_bianhao_LostFocus()Setrst=ExecuteSQL("select*from员工信息where员工编号='"&Trim(txt_bianhao.Text)&"'",msg_sql)Ifrst.RecordCount=0ThenMsgBox"无此人"txt_bianhao.SetFocustxt_bianaho.Text=""ExitSubEndIfSetrst=ExecuteSQL("select*from员工信息where员工编号='"&Trim(txt_bianhao.Text)&"'",msg_sql)txt_xingming.Text=rst.Fields(0)EndSub3.4.10按员工查询选择“工资查询〞->“按员工查询〞,输入员工编号和姓名,单击“查询〞即可查看个人工资情况。Dimmsg_sqlAsStringDimobjrsAsADODB.RecordsetPrivateSubcmd_cancel_Click()frm_main.Showfrm_main.xitong.Enabled=False'在这里设计非管理员用户的权限,这里我假设让非管理员用户不能用菜单中的‘系统’frm_main.shezhi.Enabled=Falsefrm_main.xinxiweihu.Enabled=FalseUnloadMeEndSubPrivateSubcmd_search_Click()Setobjrs=ExecuteSQL("select*from工资信息where员工编号='"&Trim(txt_bianhao.Text)&"'",msg_sql)SetDataGrid1.DataSource=objrsEndSub3.4.11按部门查询选择“工资查询〞->“按部门查询〞,输入部门编号和名称,单击“查询〞即可查看工资。Dimmsg_sqlAsStringDimobjrsAsADODB.RecordsetPrivateSubcmd_cancel_Click()frm_main.Showfrm_main.xitong.Enabled=False'在这里设计非管理员用户的权限,这里我假设让非管理员用户不能用菜单中的‘系统’frm_main.shezhi.Enabled=Falsefrm_main.xinxiweihu.Enabled=FalseUnloadMeEndSubPrivateSubcmd_search_Click()DimsearchsqlAsStringsearchsql="select工资信息.员工编号,姓名,根本工资,岗位工资,水电费,实发金额from工资信息,部门信息,员工信息where员工信息.所属部门='"_&Trim(txt_bianhao.Text)&"'"_&"AND工资信息.员工编号=员工信息.员工编号AND部门信息.部门编号=员工信息.所属部门"Setobjrs=ExecuteSQL(searchsql,msg_sql)SetDataGrid1.DataSource=objrsEndSub模块一:PublicpowerAsStringPublictempuserAsStringPubliccnModAsNewADODB.ConnectionPublicUserNameAsStringPublicUserPwdAsStringPublicFunctionExecuteSQL(ByValsqlAsString,MsgStringAsString)AsADODB.RecordsetDimcn

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论