1、 delphi课程设计 48 2020年4月19日 文档仅供参考 学号: 09416305 课程设计报告 课 程 名 称: Delphi程序设计 题 目: 人事管理系统 姓 名: 学 院: 专业班级: 计算机091 指 导 教 师: 课程设计任务书
2、 班级 计算机091 姓名 李琳蕊 一、设计题目:人事管理系统设计 二、设计内容: 本设计是制作一个人事管理系统,在该程序中具体功能要求见附件。 三、基本要求: 1、 对源程序编写的要求: (1)能够实现任务书中的功能; (2)尽可能使界面友好、直观、易操作; (3)源程序要有适当的注释,使程序容易阅读。 2、 撰写“课程设计报告”,撰写要求见附件实习报告撰写排版要求。 3、 课程设计验收要求: (1)运行所设计的系统; (2)回答有关问题; (3)提交课程设计报告和任务书; (4)提交
3、源程序 四、进度安排: 1、系统分析、设计准备阶段:4学时 2、编程调试阶段:32学时 3、总结和书写报告阶段:2学时 4、考核阶段:2学时 指导教师: 刘俊 年 1 月 6 日 目 录 人事管理系统 3 1、需求分析 3 2、程序要求 3 1.功能模块图 3 2.系统界面 4 2:登陆界面 5 3: 8 4:更改界面 12 5:MDICHild 15 6: 17 3.创立
4、数据库 24 1、数据库的选择:ACCESS 数据库 24 2、建表 24 4、系统设计 29 5、系统的使用说明 29 6、心得体会 29 7:致谢 30 参考文献 30 人事管理系统 1、需求分析 1.新员工资料输入。 2.自动分配员工号,而且设置初始的用户密码,能够分配权限执行不同的模块。 3.人事变动的详细记录,包括岗位和部门的调整。 4.员工信息的查询和修改,包括员工个人信息和密码等。 5.帮助。 2、程序要求 1.功能模块图 人事管理系统 根据权限登录 帮助 新员工档案输入 人事变更 员工
5、档案查询修改 2.系统界面 1:进入界面; 代码:procedure Tqdform.FormCreate(Sender: TObject); var windowid:hwnd; begin windowid:=findwindow(nil,'F_main'); if windowid<>0 then begin MessageBox(handle,'错误:系统已经启动!','系统启动错误 ',MB_OK or MB_ICONERROR); // showwindow(foundwin,9);
6、 halt; end; end; end. 2:登陆界面 代码:unit login; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls,Inifiles; type TF_login = class(TForm) Label1: TLabel; Label2: TLabel; Label3: TLabel; Label4: TLabel;
7、 i_server_add: TComboBox; i_user: TEdit; i_passwd: TEdit; Button1: TButton; Button2: TButton; procedure Button1Click(Sender: TObject); procedure FormShow(Sender: TObject); procedure FormCreate(Sender: TObject); procedure FormClose(Sender: TObject; var Acti
8、on: TCloseAction); private { Private declarations } public { Public declarations } end; var F_login: TF_login; Inifile:TInifile; implementation uses DataModule, crypt, mainwin; {$R *.DFM} procedure TF_login.Button1Click(Sender: TObject); var passwd, passwrd:
9、String; begin application.CreateForm(TDataModule1,DataModule1); With DataModule1 do begin Database.Connected:=False; Database.AliasName:=i_server_add.Text; Database.Connected:=True; T_user.Filter:='ID='''+i_user.Text+''''; T_user.Filtered:=True; T_user.Open;
10、 if T_user.RecordCount=1 then begin passwd:=i_passwd.Text; if length(passwd)>5 then begin passwd:=Copy(passwd+passwd,1,10);//统一密码长度 passwd:=Encrypt(passwd,123);//加密 end; passwrd:=T_user['PASSWD']; if (passwrd=passwd) and (T_user['AU
11、THORITY']='3') then begin F_main.login:=True; end else Application.MessageBox('请重新输入密码。'+#13+'注意大小写!','密码错误',MB_OK); end else Application.MessageBox('请确认用户名大小写是否正确!','无此用户',MB_OK); T_user.Close; end; if F_main.login then F_login
12、Close else DataModule1.Free; end; procedure TF_login.FormShow(Sender: TObject); begin self.i_server_add.SetFocus; end; procedure TF_login.FormCreate(Sender: TObject); begin Inifile:=TInifile.Create(extractfilepath(paramstr(0))+'SERVER.ini') ; if fileexists(extractfilepath(p
13、aramstr(0))+'SERVER.ini') then begin i_server_add.Text:=inifile.ReadString('SERVER','SERVER NAME',''); i_user.Text:=inifile.ReadString('SERVER','USER NAME',''); end; end; procedure TF_login.FormClose(Sender: TObject; var Action: TCloseAction); begin if not fileexists(
14、extractfilepath(paramstr(0))+'SERVER.ini') then Inifile:=TInifile.Create(extractfilepath(paramstr(0))+'SERVER.ini') ; inifile.WriteString('SERVER','SERVER NAME',i_server_add.Text); inifile.WriteString('SERVER','USER NAME',i_user.Text); inifile.Free; end; End. 3: 代码:unit a
15、dd; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, childwin, StdCtrls, DBCtrls, Mask, ExtCtrls; type TF_add = class(TMDIChild) Label1: TLabel; Label2: TLabel; Label3: TLabel; Label5: TLabel; Label6: TLabel; Lab
16、el7: TLabel; Label9: TLabel; Label10: TLabel; Label11: TLabel; Label12: TLabel; Label13: TLabel; Label14: TLabel; i_department: TDBLookupComboBox; i_job: TDBLookupComboBox; i_edu_level: TDBLookupComboBox; Button1: TButton; i_user: TDBEdit;
17、i_name: TDBEdit; i_birthday: TDBEdit; i_specialty: TDBEdit; i_address: TDBEdit; i_tel: TDBEdit; i_email: TDBEdit; i_remark: TDBMemo; i_passwd: TEdit; i_sex: TDBRadioGroup; DBLookupComboBox1: TDBLookupComboBox; procedure FormCreate(Sender: TObject);
18、 procedure Button1Click(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); private { Private declarations } procedure AddInit; public { Public declarations } end; var F_add: TF_add; implementation uses DataModule, mainwin, cr
19、ypt; {$R *.DFM} procedure TF_add.AddInit; var counter:integer; id:String; begin With DataModule1 do begin //生成员工号 T_counter.Filter:='ID=''P'''; T_counter.Filtered:=True; T_counter.Open; counter:=T_counter['COUNTER_VALUE']; T_counter.Close; id:='
20、00000'+IntToStr(counter); id:='P'+Copy(id,length(id)-4,5); //增加新记录 T_add_user.Open; T_add_user.Append; T_add_user['ID']:=id; T_add_user['SEX']:='M'; T_add_user['STATE']:='T'; i_passwd.Text:=id; end; end; procedure TF_add.FormCreate(Sender: TObject); be
21、gin F_main.M_add.Enabled:=False; F_main.TB_add.Enabled:=False; Width:=272; Height:=469; datamodule1.T_department.Open; With DataModule1 do begin if not T_department.Active then T_department.Open; if not T_job.Active then T_job.Open; if not T_edu_level.Active then
22、T_edu_level.Open; end; AddInit; end; procedure TF_add.Button1Click(Sender: TObject); var passwd:String; counter:Integer; begin if length(i_name.Text)>0 then begin passwd:=i_passwd.Text; passwd:=Copy(passwd+passwd,1,10); passwd:=Encrypt(passwd,123); With Da
23、taModule1 do begin //累加员工编号计数器 T_counter.Filter:='ID=''P'''; T_counter.Filtered:=True; T_counter.Open; T_counter.Edit; T_counter['COUNTER_VALUE']:=T_counter['COUNTER_VALUE']+1; T_counter.Post; T_counter.Close; //增加员工个人信息记录 T_
24、add_user.Edit; T_add_user['PASSWD']:=passwd; T_add_user.Post; //获取人事变动记录号 T_counter.Filter:='ID=''C'''; T_counter.Filtered:=True; T_counter.Open; counter:=T_counter['COUNTER_VALUE']; Inc(counter); T_counter.Edit; T_counter['COUNTE
25、R_VALUE']:=counter; T_counter.Post; T_counter.Close; //追加人事变动记录 T_change.Open; T_change.Append; T_change['ID']:=counter; T_change['PERSON']:=i_user.Text; T_change['CHANGE']:='2'; T_change['RECORD_TIME']:=Now; T_change['DESCRIPTION
26、']:='加入公司。'; T_change.Post; T_change.Close; end; AddInit; end; end; procedure TF_add.FormClose(Sender: TObject; var Action: TCloseAction); begin inherited; F_main.M_add.Enabled:=True; F_main.TB_add.Enabled:=True; With DataModule1 do begin T_add_use
27、r.Cancel; T_add_user.Close; end; end; End. 4:更改界面 代码:unit change; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, childwin, StdCtrls, ExtCtrls, DBCtrls, Mask; type TF_change = class(TMDIChild) Label1: TLabel; i_id:
28、 TEdit; GroupBox1: TGroupBox; Label2: TLabel; Label3: TLabel; Label4: TLabel; i_change: TRadioGroup; Button1: TButton; Label5: TLabel; i_department: TDBLookupComboBox; i_name: TDBEdit; i_job: TDBLookupComboBox; Label6: TLabel; i_description
29、 TMemo; i_time: TMaskEdit; procedure i_idChange(Sender: TObject); procedure FormCreate(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure Button1Click(Sender: TObject); private { Private declarations } procedure ChangeIn
30、it; public { Public declarations } end; var F_change: TF_change; implementation uses DataModule, mainwin; {$R *.DFM} procedure TF_change.ChangeInit; begin i_id.Text:=''; //清空员工号输入框 DataModule1.T_user.Close; //关闭员工查询数据表 i_change.ItemIndex:=0;
31、 //默认员工变动为职务变更 i_time.Text:=DateToStr(Now); //加入当前时间 i_description.Clear; //清空描述 end; procedure TF_change.i_idChange(Sender: TObject); begin With DataModule1 do begin T_user.Filter:='ID='''+i_id.Text+''''; T_user.Filtered:=True; T_user.Ope
32、n; end; end; procedure TF_change.FormCreate(Sender: TObject); begin F_main.M_change.Enabled:=False; F_main.TB_change.Enabled:=False; Width:=282; Height:=429; With DataModule1 do begin if not T_dep
33、artment.Active then T_department.Open; if not T_job.Active then T_job.Open; end; ChangeInit; end; procedure TF_change.FormClose(Sender: TObject; var Action: TCloseAction); begin inherited; //继承父类的关闭事件 F_main.M_change.E
34、nabled:=True; // 恢复菜单的使用 F_main.TB_change.Enabled:=True; //恢复按钮的使用 end; procedure TF_change.Button1Click(Sender: TObject); var counter:integer; //保存计数器 begin With DataModule1 do //设置默认前缀为DataModule1 begin if T_user.RecordCount=1 then //判断是否存在该员工 begin
35、 //获取人事变动记录号 T_counter.Filter:='ID=''C'''; T_counter.Filtered:=True; T_counter.Open; counter:=T_counter['COUNTER_VALUE']; counter:=counter+1;; T_counter.Edit; T_counter['COUNTER_VALUE']:=counter; //把新的计数器的值写入表中
36、 T_counter.Post; //保存表的记录 T_counter.Close; //关闭表 //追加人事变动记录 T_user.Edit; if i_change.ItemIndex=1 then T_user['STATE']:='F'; //取消员工帐号 T_user.Post;
37、 //保存 T_change.Open; //修改人事变动记录 T_change.Append; T_change['ID']:=counter; T_change['PERSON']:=i_id.Text; T_change['CHANGE']:=IntToStr(i_change.ItemIndex); T_change['RECORD_TIME']:=StrToDate(i_time.Text); T_chang
38、e['DESCRIPTION']:=i_description.Text; T_change.Post; //保存 T_change.Close; //关闭 ChangeInit; //在初始化表单 end else Application.MessageBox('请确认员工号!','输入错误',MB_OK); end; end; End. 5:MDICHild
39、 代码:unit Childwin; interface uses Windows, Classes, Graphics, Forms, Controls, StdCtrls; type TMDIChild = class(TForm) procedure FormClose(Sender: TObject; var Action: TCloseAction); private { Private declarations } public { Public declarations } end; implemen
40、tation {$R *.DFM} procedure TMDIChild.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; End. 6: 数据连接 代码:unit DataModule; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, Db, DBTables; type TDa
41、taModule1 = class(TDataModule) Database: TDatabase; T_user: TTable; T_add_user: TTable; DS_add_user: TDataSource; T_counter: TTable; T_department: TTable; DS_department: TDataSource; T_job: TTable; T_edu_level: TTable; DS_job: TDataSource; DS_ed
42、u_level: TDataSource; T_change: TTable; DS_user: TDataSource; T_user_2: TTable; DS_user_2: TDataSource; T_change_list: TTable; DS_change_list: TDataSource; T_changed: TTable; DS_changed: TDataSource; private { Private declarations } public { Pu
43、blic declarations } end; var DataModule1: TDataModule1; implementation {$R *.DFM} End. 7:主窗口设计 代码: About, login, DataModule, add, change, search; procedure TF_main.M_aboutClick(Sender: TObject); begin AboutBox.ShowModal; end; procedure TF_main.M_connectClick(Sender: T
44、Object); begin application.CreateForm(TF_login,F_login); F_login.ShowModal; if login then begin M_connect.Enabled:=False; TB_connect.Enabled:=False; M_disconnect.Enabled:=True; TB_disconnect.Enabled:=True; M_add.Enabled:=True; TB_add.Enabled:=True; M_c
45、hange.Enabled:=True; TB_change.Enabled:=True; M_search.Enabled:=True; TB_search.Enabled:=True; StatusBar1.Panels[1].Text:='已经连接到服务器:'+F_login.i_server_add.Text; end; end; procedure TF_main.FormCreate(Sender: TObject); begin //初始化 login:=False; M_connect.Enabled:=
46、True; TB_connect.Enabled:=True; M_disconnect.Enabled:=False; TB_disconnect.Enabled:=False; M_add.Enabled:=False; TB_add.Enabled:=False; M_change.Enabled:=False; TB_change.Enabled:=False; M_search.Enabled:=False; TB_search.Enabled:=False; StatusBar1.Panels[1].Text:='尚未登录
47、服务器!请按F2登录。'; end; procedure TF_main.M_disconnectClick(Sender: TObject); var i:integer; begin for i:=MDIChildCount-1 downto 0 do F_main.MDIChildren[i].Close; DataModule1.Database.Connected:=False; FormCreate(nil); datamodule1.Free; end; procedure TF_main.M_exitClick(Sen
48、der: TObject); begin Close; end; procedure TF_main.M_addClick(Sender: TObject); begin Application.CreateForm(TF_add,F_add); end; procedure TF_main.M_changeClick(Sender: TObject); begin Application.CreateForm(TF_change,F_change); end; procedure TF_main.M_searchClick(Sender: TO
49、bject); begin Application.CreateForm(TF_search,F_search); end; End. 8:修改界面 代码:unit search; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, childwin, DBCtrls, Grids, DBGrids, StdCtrls, Mask, ExtCtrls, DBCGrids; type TF_search = cl
50、ass(TMDIChild) Label1: TLabel; Label2: TLabel; i_id: TEdit; Button1: TButton; Label3: TLabel; Label5: TLabel; Label6: TLabel; Label7: TLabel; Label8: TLabel; Label9: TLabel; Label10: TLabel; Label11: TLabel; Label12: TLabel; Label






