用VC制作一个工资管理系统.doc

上传人:牧羊曲112 文档编号:1924487 上传时间:2022-12-26 格式:DOC 页数:39 大小:687KB
返回 下载 相关 举报
用VC制作一个工资管理系统.doc_第1页
第1页 / 共39页
用VC制作一个工资管理系统.doc_第2页
第2页 / 共39页
用VC制作一个工资管理系统.doc_第3页
第3页 / 共39页
用VC制作一个工资管理系统.doc_第4页
第4页 / 共39页
用VC制作一个工资管理系统.doc_第5页
第5页 / 共39页
点击查看更多>>
资源描述

《用VC制作一个工资管理系统.doc》由会员分享,可在线阅读,更多相关《用VC制作一个工资管理系统.doc(39页珍藏版)》请在三一办公上搜索。

1、案例四用VC+制作一个工资管理系统关键词:VC+数据库 数据表 控件绑定 统计计算4.1 课程设计的目的和意义工资管理是任何企事业单位都需要进行的一项工作,因此,开发制作工资管理系统具有较大的社会现实意义,同时工资管理系统的最大特征是数据处理,它是数据库应用系统的典范,它具有一切数据库应用系统的特征,如数据录入,数据统计和数据报表等,其系统结构与现实生活紧密结合,具体直观。工资管理系统也是数据库应用开发中经常进行例证的好例子,它的开发应用简单而又不失一般性。作为一个案例,我们仍需要重复进行一些过程,如创建工程框架,引入数据源,建立消息映射,最终实现统计计算。本程序比较简单,我们的目的是让读者对

2、VC的编程逐步加以理解,它的意义是非常重要的。4.2 系统功能设计在本系统的设计中,将主要实现如下的一些功能:增加记录功能、修改记录功能、删除记录功能、刷新记录功能,最后实现统计计算功能。4.3 数据库与数据表的设计作为工资管理系统,它是数据库应用系统数据处理的典范,数据库应用系统开发的前提是首先开发数据库和数据库中的数据表。因此在本案例中,我们仍采用Microsoft Access 2003创建数据库和数据表。为此我们先定义一个“职工工资数据表”的结构,如表4.1所示。表4.1 “职工工资数据表”结构字段名称字段类型字段大小小数位数索引必须填写年份数字整型是月份数字整型是输入日期日期/时间默

3、认是职工编号数字整型是姓名文本16是部门文本20是基本工资数字长整型自动是业绩工资数字长整型自动是奖金数字长整型自动是津贴数字长整型自动是各种补助数字长整型自动是应发数数字长整型自动是水电费数字长整型自动是房租数字长整型自动是储蓄数字长整型自动是会费数字长整型自动是保险数字长整型自动是扣除总计数字长整型自动是实发工资数字长整型自动是创建数据库及其数据表的步骤如上:(1)启动Microsoft Office 2003中的Microsoft Access应用程序,出现图4.1所示界面,通过该界面可以创建一个新的数据库或打开一个已经存在的数据库。图4.1 新建数据库选择(2)选择创建新数据库,即选择

4、“空Access数据库”选项。(3)单击“确定”按钮之后出现保存对话框,确定保存数据库的文件位置(D: VC+写作案例CH4)并给定数据库名称:工资管理数据库;然后出现图4.2所示界面。图4.2 数据库中的数据表设计界面在数据库设计界面中,用户可以打开已经存在的数据表,也可以创建新的数据表。(4)单击“设计”菜单,即出现一个数据表设计器,用户可以在其中设计一个新的数据表结构,如图4.3所示。图4.3 数据表设计器在Microsoft Access 2003数据库设计器中,用户可以定义数据表的字段名称、字段类型、字段大小等数据表结构的内容。数据表结构一经确定,用户可以打开该数据表,在数据表中输入

5、一些基本数据,以在后面的系统设计中体现设计的效果。最后,系统自动将创建的数据表保存在“D:VC+写作案例CH432资管理数据库”中,将创建的数据表命名为“职工工资数据表”。注意,在微软的Microsoft Access各版本之间,如在Microsoft Access 98与Microsoft Access 2003中,采用旧版本创建的数据库及其数据库中的数据表如要在新的版本中运用,往往需要在新版本中进行转换才行。4.4 创建工资管理系统基本框架在前面我们已经创建了“工资管理数据库”、“职工工资数据表”。它可为应用程序提供一个数据源。应用程序就是对该数据源的记录进行访问、增加、删除以及数据管理的

6、一切操作。有了这一切的工作,用户就可以着手进行应用系统的构建了。与前面的案例一样,在VC+应用系统创建中,需要通过向导先创建一个应用程序框架,然后再加入数据控件,与数据源进行绑定,并进行程序的修改与加工制作。创建“工资管理系统”应用程序框架的步骤如下:(1)结束数据库的创建并启动VC+,出现VC+主控界面。(2)在VC+主控界面中单击“文件|新建”菜单项,出现新建工程类型选择对话框,在工程类型列表中选择MFC AppWizard(EXE)工程类型。(3)输入工程名称为“工资管理系统”,并选择Win32平台类型。(4)单击“确定”按钮,进入文档类型设置。(5)选择单文档类型,即创建一个单文档界面

7、的应用程序,设置资源使用语言为中文,选择文档查看体系结构支持。(6)单击“下一步”按钮,进入框架设置的第2步,出现图4.4所示对话框。在该对话框中,需要用户对数据库的类型作一些相关的选择。图4.4 程序框架设置的第2步(7)选择“查看数据库不使用文件支持”;这时候Data Source按钮处于可用状态(或激活状态);在这一种选择下,VC+将为应用系统引入数据环境,即数据源,该数据源就是我们在前面创建的“工资数据库”,而不使用其他类型数据的文件支持。但数据源在系统制作中的引入需要用一定的驱动程序为之进行。(8)单击“Data Source”按钮,出现图4.5所示的选择数据源类型的对话框。图4.5

8、 数据源创建类型注意,在ODBC数据源文件列表中,我们已经创建了一个ODBC数据源文件,因此可以在其中直接选择引用即可。如果没有“工资管理数据库”这样的文件,则往往需要用操作系统控制面板中的ODBC程序加以创建,其方法参考案例一。(9)单击OK按钮,出现数据源中的数据表,即工资数据库中的数据表。选择“职工工资数据表”,如图4.6所示。图4.6 选择职工工资数据表(10)单击OK按钮选定该数据表。然后返回到图4.4所示对话框,完成数据源的创建工作。(11)在图4.4所示对话框中单击“完成”按钮,即完成应用程序框架的生成工作,出现工程框架创建的全部信息,该信息将提示用户所创建的应用程序框架包括的内

9、容,如:应用系统名称、界面类型、适合的操作系统、类文档的创建和系统特色等,如下所示:Application type of 工资管理系统: Single Document Interface Application targeting:Win 32Classes to be created:Application: CMyApp in 工资管理系统.h and 工资管理系统.cppFrame: CMainFrame in MainFrm.h and MainFrm.cppDocument: CMyDoc in 工资管理系统Doc.h and 工资管理系统Doc. CppRecordView :

10、 CMyView in 工资管理系统View. h and 工资管理系统View. cppRecordset: CMyset. in 工资管理系统Set.h and 工资管理系统Set.cpp(connected to table 职工工资数据表 in data source 工资管理数据库)Features:+ Initial toolbar in main frame+ Initial status bar in main frame+ Frinting and Print Preview support in view+ 3D Controls+ Uses shared DLL impl

11、ementation (MFC42.DLL)+ Database support, without file support+ ActiveX Controls support enabled+ Localizable text in:中文中国确认创建信息之后,出现应用程序框架界面,如图4.7所示。图4.7 应用程序框架界面4.5 开发工资处理界面如前所述,应用系统向导只能生成一个应用程序基本框架,该框架还不具备任何功能,我们需要在框架的基础上进行系统各种功能的制作。通常一个应用程序框架生成两个对话框,一个是IDD_ABOUTBOX对话框,它是一个说明该系统的对话框,几乎由向导自动完成,如图4

12、.8所示。图4.8 ABOUTBOX对话框该对话框仍然是基本的,如果用户需要修饰或修改,可以根据自己的需要进行。在基本框架中另外一个对话框就是主对话框IDD_MY_FORM,它是我们加工制作的主要内容,数据源也是专门为该对话框引入的。4.5.1 主对话框IDD_MY_FORM中控件的加入与布局在工资管理系统中,主对话框主要用于处理工资管理的一切内容。制作该对话框的主要步骤如下:(1)在主对话框IDD_MY_FORM中将提示文本框“TODO:在这个对话框里设置表格控制。”删除。(2)在主对话框IDD_MY_FORM中放入各种需要的控件,如标签控件、编辑框控件、命令按钮控件,其对话框布局如图4.9

13、所示。图4.9 主对话框IDD_MY_FORM控件布局其中,各个控件的属性设置如表4.2-表4.5所示。表4.2 标签对象的基本属性ID标题内容IDC_STATICCAPTION职工工资管理系统IDC_STATICNE年份IDC_STATICYF月份IDC_STATICZGBH职工编号IDC_STATICZGXM职工姓名IDC_STATICZGBM部门IDC_STATICJBGZ基本工资IDC_STATICJJ奖金IDC_STATICYJGZ业绩工资IDC_STATICJT津贴IDC_STATICGZBZ各种补助IDC_STATICRDF水电费IDC_STATICFZOU房租IDC_STATI

14、CCX储蓄IDC_STATICHF会费IDC_STATICBX保险IDC_STATICYFHJ应发合计IDC_STATICKCHJ扣除合计IDC_STATICSFGZ实发工资表4.3 编辑框控件的基本属性和编辑内容ID编辑内容IDC_EDITNF年份IDC_EDITYF月份IDC_EDITZGBH职工编号IDC_EDITZGBM所在部门IDC_EDITZGXM职工姓名IDC_EDITJBGZ基本工资IDC_EDITJJ奖金IDC_EDITYJGZ业绩工资IDC_EDITJT津贴IDC_EDITGZBZ各种补助IDC_EDITRDF水电费IDC_EDITFZOU房租IDC_EDITCX储蓄IDC

15、_EDITHF会费IDC_EDITBX保险IDC_EDITYFHJ应发合计IDC_EDITKCHJ扣除合计IDC_EDITSFGZ实发工资表4.4 命令按钮对象的基本属性ID标题内容IDC_BUTIONFIRST|-第一条IDC_BUTIONNEXT-下一条IDC_BUTIONPREV-前一条IDC_BUTIONLAST-|最后一条IDC_BUTIONSUM执行统计IDC_RADIOADD增加记录IDC_RADIODELETE删除记录IDC_RADIOUPDATE刷新记录表4.5 分组控件对象的基本属性ID标题IDC_STATICDATA工资数据处理IDC_STATICBROWSE工资数据浏览

16、IDC_STATICADDDELETUPD增加与删除IDC_STATICCOUNT个人工资统计4.5.2 为编辑框控件建立数据字段映射在对话框中的一切编辑框控件,均是用于进行数据处理和数据显示的,但首先我们应该为它们建立字段映射,即将创建的数据集中的每一个字段与一个编辑框进行数据绑定”。其方法我们在前面的案例中已经有所涉及。我们以其中的一个编辑框,即“年份”编辑框为例,说明为编辑框与数据集中的字段建立映射关系的方法。为此进行如下操作:(1)在主对话框IDD_MY FORM中选取“年份”编辑框控件。(2)用鼠标右键单击该对话框,出现一个快捷菜单。(3)在快捷菜单中单击“建立类向导”,出现类向导对

17、话框。(4)在类向导对话框中将页面切换至Member Variables页面并设置类名为CmySet。该对话框列出了数据集的全部字段名、字段类型和字段的成员变量名称,但成员变量名是在创建数据源时自动生成的,往往不便于与编辑框建立映射关系,为此将全部成员变量名称删除,并重新定义字段的成员变量名称。重新定义后的字段变量名称如图4.10所示。图4.10 重新定义的字段变量名称(5)在Classname列表中选择CmyView,出现为编辑框控件与字段成员变量建立消息映射的页面,如图4.11所示。图4.1l 编辑框控件与字段变量映射页面(6)选中IDC_EDITNF(年份编辑)控件资源索引,再单击Add

18、 Variable按钮,出现变量选择列表框。在字段选择列表框中选择“年份”成员变量,如图4.12所示。图4.12 字段成员变量列表(7)单击OK按钮,即完成“年份”编辑框与“年份”字段成员变量的映射。采用相同的方法为全部编辑框控件建立消息映射,然后编译对话框,则发现可以在编辑框中修改数据表中的记录。4.5.3 为命令按钮增加函数并编制过程代码事实上,在前面我们已经在编辑框与数据集之间建立了一种映射关系,但处理数据的功能还不是很完善。为此我们需要用一些命令来完成对数据的操作,需要为命令按钮建立函数和编制过程代码。同样,在对话框中存在多个命令按钮,我们以“第一条记录”命令按钮为例来说明建立函数与编

19、制过程的方法。1.“第一条记录”命令按钮的过程代码(1)在对话框中选取“第一条记录”命令按钮。(2)用鼠标右键单击该命令按钮,出现一个快捷菜单。(3)在快捷菜单中单击“建立类向导”菜单项,出现一个消息映射的对话框。(4)在消息映射的对话框中选择Message Maps页面,选择消息类型为“ON_CLICKED”并单击Add Function按钮,出现一个函数命令对话框,建议接受系统命名的函数名即可。(5)确认函数名后单击Edit Code按钮,出现代码编辑框,在代码编辑框中编辑命令按钮的代码,如下所示:void CMyView : : OnButtonfirst ()/ / TODO: Add

20、 your control notification handler code herem_pSet - MoveFirst ();if (m_pSet - IsBOF()MessageBox (“记录已经在第一条!”)m_pSet - MoveNext ();UpdateData (FALSE);Return;UpdateData (FALSE);这样,“第一条记录”命令按钮的过程代码就编辑完成了。采用同样的方法,我们可以编辑其他命令按钮的过程代码。2“下一条记录”命令按钮的过程代码void CMyView : : OnButtonnext ()/ / TODO: Add your cont

21、rol notification handler ode herem_pSet - MoveNext();if (m_pSet - IsEOF () MessageBox (“记录已经在最后一条!”);m_pSet - MovePrev ();UpdateData (FALSE);Return;UpdateData (FALSE);3“前一条记录”命令按钮的过程代码void CMyView : : OnButtonprev ()/ / TODO: Add your control notification handler code herem_pSet - MovePrev ();if (m_

22、pSet - IsBOF() MessageBox (“记录已经在第一条!”);m_pSet - MoveNext ();UpdateData (FALSE);return;UpdateData (FALSE);4“最后一条记录”命令按钮的过程代码void CMyView : : OnButtonlast ()/ / TODO: Add your control notification handler code herem_pSet - MoveLast ();if (m_pSet - IsEOF ()MessageBox (“记录已经在最后一条!”);m_pSet - MovePrev (

23、);UpdateData (FALSE);Return;UpdateData (FALSE);5“增加记录”选项按钮的过程代码void CMyView : : OnRadiodd ()/TODO: Add your control notification handler code herem_pSet - AddNew ();UpdateData (FALSE);6“删除记录”选项按钮的过程代码void CMyView : : OnRadiodelete ()/TODO: Add your control notification handler code herem_pSet - Dele

24、te ();m_pSet - MoveNext ();if (m_pSet - IsEOF () m_pSet - MoveLast ();if (m_pSet - IsBOf() m_pSet - SetFieldNull (NULL);UpdateData (FALSE);7“刷新记录”选项按钮的过程代码void CMyView : : OnRadioupdate ()/TODO: Add your control notification handler code herem_pSet-Edit ();UpdateData ();m_pSet- Update ();m_pSet- Req

25、uery ();m_pSet- CancelUpdate ();8“执行统计”命令按钮的过程代码void CMyView : : OnButtonsum ()/TODO: Add your control notification handler code herem_pSet-Edit ();m_pSet-m_YES = m_pSet -m_JBGZ+m_pSet-m_JJ+m_pSet-m_YJGZ+m_pSet-m_JT+ m_pSet-m_GZBZ;m_pSet-m_KCZJ=m_pSet-m_CX+m_pSet-m_HF+m_pSet-m_FZOU+m_pSet-m_RDF +m_p

26、Set-m_BX;m_pSet-m_SFGZ= m_pSet-m_YES- m_pSet-m_KCZZ;UpdateData (FALSE);m_pSet-Requery();m_pSet-Update();最后编译执行工程,检验对话框中的数据处理效果,如图4.13所示。图4.13 对话框运行效果4.5.4 资源文件分析在工程创建完成后,读者可以对已经创建的工程的一些文件进行阅读和分析。人们常说:软件=文档+代码,这一“等式”几乎对于一切的开发平台都是适用的;这里的文档包括用户创建的文档和系统派生的文档两类,无论是用户创建的文档或是系统派生的文档,它们往往都是对系统开发的过程的“记录”。因此,

27、通过阅读这些“记录”,不仅对VC+开发环境有了更深入的了解,而且对整个系统的实现全过程也一清二楚。本小节分析两个文档,一个是工程实现文档,另一个是工程设置文档。1“工资管理系统”工程实现文件工资管理系统实现文件记录了该工程创建的声明、编写的过程代码、资源的消息映射、数据集的创建和控件映射等等内容,工程实现文档往往是用户开发过程中编写最多的文档,一切的过程代码编制往往都是在工程实现文档中进行的。“工资管理系统”工程实现文档的全部内容如下所示(仅供读者在开发实践中参考,若无必要,也可以略去对这部分的阅读):/工资管理系统View.cpp : implementation of the CMyVie

28、w class# include “stdafx.h”# include “工资管理系统.h”# include “工资管理系统Set.h”# include “工资管理系统Doc.h”# include “工资管理系统View.h”# ifdef _DEBUG# define new DEBUG_NEW# undef THIS_FILEstatic char THIS_FILE = _FILE_;# endif/CMyViewIMPLEMENT_DYNCREATE (CMyView, CRecordView)BEGIN_MESSAGE_MAP (CMyView, CRecordView)/A

29、FX_MSG_MAP (CMyView) ON_BN_CLICKED (IDC_BUTTONFIRST, OnButtonfirst)ON_BN_CLICKED (IDC_BUTTONNEXT, OnButtonnext)ON_BN_CLICKED (IDC_BUTTONPREV, OnButtonprev)ON_BN_CLICKED (IDC_BUTTONLAST, OnButtonlast)ON_BN_CLICKED (IDC_RADIODD, OnRadiodd)ON_BN_CLICKED (IDC_RADIODELETE, OnRadelete)ON_BN_CLICKED (IDC_R

30、ADIOUPDATE, OnRadioupdate)ON_BN_CLICKED (IDC_BUTTONSUM, OnButtonsum)ON_BN_CLICKED (IDC_RADIOEDIT, OnRadioedit)/AFX_MSG_MAP/Standard printing commandsON_COMMAND (ID_FILE_PRINT, CRecordView : : OnFilePrint)ON_COMMAND (ID_FILE_DIRECT, CRecordView : : OnFilePrint)ON_COMMAND (ID_FILE_PREVIEW, CRecordView

31、 : : OnFilePrieview)END_MESSAGE_MAP ()/ / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / / /CMyView construction/destructionCMyView : : CMyView (): CRecordView (CMyView : : IDD)/AFX_DATA_INIT (CMyView)m_pSet = NULL;/ AFX_DATA_INIT/TODO: add construction

32、 code hereCMyView : : CMyView ()void CMyView : : DoDataExchange (CDataExchange* pDX)CRecordView : : DoDataExchange (pDX);/AFX_DATA_MAP (CMyView)DDX_FieldText (pDX, IDC_EDITNF, m_pSet - m_NF, m_pSet);DDX_FieldText (pDX, IDC_EDITYF, m_pSet - m_YF, m_pSet);DDX_FieldText (pDX, IDC_EDITZGBH, m_pSet - m_Z

33、GBH, m_pSet);DDX_FieldText (pDX, IDC_EDITZGBM, m_pSet - m_BM, m_pSet);DDX_FieldText (pDX, IDC_EDITZGXM, m_pSet - m_XM, m_pSet);DDX_FieldText (pDX, IDC_EDITJBGZ, m_pSet - m_JBGZ, m_pSet);DDX_FieldText (pDX, IDC_EDITJJ, m_pSet - m_JJ, m_pSet);DDX_FieldText (pDX, IDC_EDITSFGZ, m_pSet - m_SFGZ, m_pSet);

34、DDX_FieldText (pDX, IDC_EDITYFHJ, m_pSet - m_YFS, m_pSet);DDX_FieldText (pDX, IDC_EDITKCHJ, m_pSet - m_KCZJ, m_pSet);DDX_FieldText (pDX, IDC_EDITBX, m_pSet - m_NF, m_pSet);DDX_FieldText(pDX, IDC_EDITBX, m_pSet-m_BX, m_pSet);DDX_ FieldText(pDX, IDC_EDITCX, m_pSet-m_CX, m_pSet);DDX _FieldText(pDX, IDC

35、 _EDITFZOU, m_pSet-m_FZOU, m_pSet);DDX _FieldText(pDX, IDC _EDITGZBZ, m_pSet-m_GZBZ, m_pSet);DDX _FieldText(pDX, IDC _EDITHF, m_pSet-m_HF, m_pSet);DDX _FieldText(pDX, IDC_ EDITJT, m_pSet-m_JT, m_pSet);DDX _FieldText(pDX, IDC_EDITRDF, m pSet-m_RDF, m pSet);DDX_FieldText(pDX, IDC_EDITYJGZ, m_pSet-m_YJ

36、GZ, m_pSet);/AFX_ DATA_ MAPBOOL CMyView : PreCreateWindow(CREATESTRUCT&/TODO: Modify the Window class or styles here by modifying/the CREATESTRUCT csreturn CRecordView : PreCreateWindow(cs);void CMyView:OnInitialUpdate()m_pSet = &GetDocument()-m_mySet;CRecordView : OnInitialUpdate();GetParentFrame (

37、) -RecalcLayout();Resize ParentToFit();/CMyView printingBOOL CMyView : OnPreparePrinting(CPrintInfo* pInfo)/default preparationreturn DoPreparePrinting(pInfo);void CMyView:OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)/TODO: add extra initialization before printingvoid CMyView : OnBeginPrintin

38、g (CDC* /*pDC*/, CPrintInfo* /*pInfo*/)/TODO: add cleanup after printing/ CMyView diagnostics# ifdef _DEBUGvoid CMyView : AssertValid () constCRecordView : AssertValid ();void CMyView : Dump (CDumpContext & sc) constCRecordView : Dump(dc);CMyDoc* CMyView : GetDocument () / non-debug version is inlin

39、eASSERT(m_pDocument-IsKindOf(RUNTIME_CLASS(CMyDoc);Return (CMyDoc*)m_pDocument;# endif /_DEBUG/CMyView database supportCRecordset* CMyView : OnGetRecordset()return m_pSet;/CMyView message handlersvoid CMyView : OnButtonfirst()/TODO: Add your control notification handler code herem_pSet-MoveFirst ();

40、if(m_pSet-IsBOF ()Mes sageBox ( 记录已经在第一条!);m_pSet-MoveNext (); UpdateData (FALSE); return; UpdateData ( FALSE);void CMyView : OnButtonnext () / TODO: Add your control notification handler code here M_ pSet-MoveNext (); If (m_pSet-IsEOF() MessageBox ( 记录已经在最后一条 ! ); m_pSet-MovePrev (); UpdateData(FAL

41、SE); return; UpdateData (FALSE);void CMyView:OnButtonprev () / TODO: Add your control notification handler code herem_pSet-MovePrev (); if(m_pSet-IsBOF() MessageBox(记录已经在第一条!); m_ pSet-MoveNext (); UpdateData(FALSE); return; UpdateData (FALSE);void CMyView:OnButtonlast () / TODO: Add your control notification handler code here m_pSet-Edit (); if m_pSet-IsEOF() MessageBox(记录已经在第一条!);m_pSet-MovePrev (); -UpdateData(FALSE);return;UpdateData(FALSE); void CMyView : OnRadiodd()

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号