版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、面向?qū)ο缶幊碳夹g(shù)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告: 學(xué)號(hào):班級(jí):指導(dǎo)老師:日期:目錄:一 設(shè)計(jì)任務(wù)與要求.31. 設(shè)計(jì)目的32. 課程設(shè)計(jì)的要求.3二 系統(tǒng)分析31. 需求分析:32. 功能分析:33. 系統(tǒng)功能模塊.34. 功能的實(shí)現(xiàn)35. 模塊框架圖.4三 系統(tǒng)設(shè)計(jì).4四 問題分析和實(shí)驗(yàn)總結(jié).10課程設(shè)計(jì)部分源代碼11 一 設(shè)計(jì)任務(wù)與要求設(shè)計(jì)題目:人事管理系統(tǒng)1.設(shè)計(jì)目的:制作人事管理系統(tǒng),實(shí)現(xiàn)對(duì)增加數(shù)據(jù)記錄,刪除記錄,排序記錄,篩選記錄數(shù)據(jù)的要求。2.課程設(shè)計(jì)的要求A用access創(chuàng)建人事管理數(shù)據(jù)表,該表記錄職工的基本信息,其中包括職工編號(hào),職工,所在部門,職工年齡,工作時(shí)間,基本工資,職稱和監(jiān)理等信息
2、。C.論述對(duì)“MFC AppEizardexe”生成的應(yīng)用程序的框架的認(rèn)識(shí),理解和開發(fā)心得二系統(tǒng)分析1.需求分析:l 可利用該程序?qū)崿F(xiàn)對(duì)職工信息的記錄和瀏覽l 能夠?qū)β毠ば畔⑦M(jìn)行輸入、刪除、排序、以及篩選等操作;2.功能分析:l 新增記錄:系統(tǒng)能在原有記錄的基礎(chǔ)上增加新的記錄。l 刪除記錄:對(duì)數(shù)據(jù)表中的數(shù)據(jù)進(jìn)行刪除。l 篩選記錄:根據(jù)職工標(biāo)號(hào)對(duì)職工進(jìn)行篩選進(jìn)行精確查找職工人員。l 排序記錄:對(duì)職工信息編號(hào)進(jìn)行從小到大的排序3.系統(tǒng)功能模塊人事管理系統(tǒng)有:新增記錄、深處記錄、排序記錄、篩選及瀏覽記錄。4.功能的實(shí)現(xiàn):1) “篩選及瀏覽記錄”模塊:在access中建表時(shí),在職工編號(hào)欄開啟關(guān)鍵詞索引
3、功能,篩選時(shí)在對(duì)話框的編輯框內(nèi)輸入要篩選的職工標(biāo)號(hào)即可進(jìn)行篩選。2) “新增記錄”模塊:3) “數(shù)據(jù)刪除模塊”顯示當(dāng)前的數(shù)據(jù)內(nèi)容,點(diǎn)擊刪除按鈕將該職工的所有信息刪除。4) “排序記錄”模塊顯示當(dāng)前數(shù)據(jù)內(nèi)容,點(diǎn)擊排序按鈕將當(dāng)前表中所有職工信息從小到大排序。5.模塊框架圖人事管理系統(tǒng)該職工信息消失排序記錄排序數(shù)據(jù)顯示當(dāng)前編號(hào)最小的職工信息刪除數(shù)據(jù)刪除記錄保存職工信息填寫信息增加記錄篩選記錄輸入編號(hào)顯示職工信息三、系統(tǒng)設(shè)計(jì)人事管理系統(tǒng).mdb表的初始化結(jié)果 1.界面設(shè)計(jì)運(yùn)行時(shí)主界面l 增加記錄界面增加信息成功:l 篩選界面篩選成功:l 排序和刪除界面刪除了李英的信息排序功能:2、程序設(shè)計(jì)通過主窗體調(diào)
4、用其他窗體,在調(diào)用增加記錄時(shí)要彈出新的對(duì)話框,一邊輸入要添加的信息。篩選記錄時(shí),要實(shí)現(xiàn)在創(chuàng)建access數(shù)據(jù)庫時(shí)打開索引功能。這樣再點(diǎn)擊篩選記錄是只要在新對(duì)話框中輸入關(guān)鍵詞職工編號(hào)便可。四、課程設(shè)計(jì)的問題分析和實(shí)驗(yàn)總結(jié)此次的人事管理系統(tǒng)的設(shè)計(jì),主要是運(yùn)用MFC操作,以讓程序更加的便于操作和使用,這其中也出現(xiàn)了不少問題,走了很多彎路,比方:1. 創(chuàng)建數(shù)據(jù)源,用控制面板設(shè)置數(shù)據(jù)源文件時(shí)老是出錯(cuò)。解決方法:先在access中創(chuàng)建人事管理系統(tǒng)表,然后在控制面板中原則添加指定數(shù)據(jù)源。2. 在寫對(duì)話框類成員函數(shù)時(shí)總出現(xiàn)大小寫錯(cuò)誤,導(dǎo)致程序編譯不能通過。解決方法:仔細(xì)檢查源代碼,利用錯(cuò)誤提示改正。3. 在編
5、寫子對(duì)話框成員函數(shù)時(shí),編譯老提示該類未申明。解決方法:原因是未在view.cpp文件中添加對(duì)應(yīng)的類頭文件,所以在對(duì)應(yīng)位置添加頭文件。4. 在添加函數(shù)中,發(fā)現(xiàn)實(shí)驗(yàn)指導(dǎo)的步驟結(jié)果增加記錄函數(shù)運(yùn)行結(jié)果不能正常添加記錄。解決方法:點(diǎn)擊增加函數(shù)時(shí),應(yīng)該彈出輸入信息對(duì)話框,以便新增職工信息,新增完畢后,點(diǎn)擊確定完成添加操作。上網(wǎng)查閱資料后,完善了增加函數(shù)代碼,并新增了一個(gè)對(duì)話框和對(duì)應(yīng)類CDlgAdd,使其能完成其指定功能。本程序部分源代碼:/ 人事管理系統(tǒng)View.cpp : implementation of the CMyView class/#include ""#include
6、 "人事管理系統(tǒng).h"#include ""#include ""#include "人事管理系統(tǒng)Set.h"#include "人事管理系統(tǒng)Doc.h"#include "人事管理系統(tǒng)View.h"#ifdef _DEBUG#define new DEBUG_NEW#undef THIS_FILEstatic char THIS_FILE = _FILE_;#endif/ CMyViewIMPLEMENT_DYNCREATE(CMyView, CRecordView)BEG
7、IN_MESSAGE_MAP(CMyView, CRecordView)/AFX_MSG_MAP(CMyView)ON_BN_CLICKED(IDC_BUTTON_ADD, OnButtonAdd)ON_BN_CLICKED(IDC_BUTTON_DEL, OnButtonDel)ON_BN_CLICKED(IDC_BUTTON_FILTER, OnButtonFilter)ON_BN_CLICKED(IDC_BUTTON_SORT, OnButtonSort)/AFX_MSG_MAP/ Standard printing commandsON_COMMAND(ID_FILE_PRINT, C
8、RecordView:OnFilePrint)ON_COMMAND(ID_FILE_PRINT_DIRECT, CRecordView:OnFilePrint)ON_COMMAND(ID_FILE_PRINT_PREVIEW, CRecordView:OnFilePrintPreview)END_MESSAGE_MAP()/ CMyView construction/destructionCMyView:CMyView(): CRecordView(CMyView:IDD)/AFX_DATA_INIT(CMyView)m_pSet = NULL;m_gzsj = 0;/AFX_DATA_INI
9、T/ TODO: add construction code hereCMyView:CMyView()void CMyView:DoDataExchange(CDataExchange* pDX)CRecordView:DoDataExchange(pDX);/AFX_DATA_MAP(CMyView)DDX_FieldText(pDX, IDC_EDIT_JBGZ, m_pSet->m_jbgz, m_pSet);DDX_FieldText(pDX, IDC_EDIT_JL, m_pSet->m_jl, m_pSet);DDX_FieldText(pDX, IDC_EDIT_S
10、ZBM, m_pSet->m_szbm, m_pSet);DDX_FieldText(pDX, IDC_EDIT_ZC, m_pSet->m_zc, m_pSet);DDX_FieldText(pDX, IDC_EDIT_ZGBH, m_pSet->m_zgbh, m_pSet);DDX_FieldText(pDX, IDC_EDIT_ZGNL, m_pSet->m_zgnl, m_pSet);DDX_FieldText(pDX, IDC_EDIT_ZGXB, m_pSet->m_zgxb, m_pSet);DDX_FieldText(pDX, IDC_EDIT_
11、ZGXM, m_pSet->m_zgxm, m_pSet);DDX_DateTimeCtrl(pDX, IDC_DATETIMEPICKER_GZSJ, m_pSet->m_gzsj);/AFX_DATA_MAPBOOL CMyView:PreCreateWindow(CREATESTRUCT& cs)/ TODO: Modify the Window class or styles here by modifying/ the CREATESTRUCT csreturn CRecordView:PreCreateWindow(cs);void CMyView:OnInit
12、ialUpdate()m_pSet = &GetDocument()->m_mySet;CRecordView:OnInitialUpdate();GetParentFrame()->RecalcLayout();ResizeParentToFit();/ CMyView printingBOOL CMyView:OnPreparePrinting(CPrintInfo* pInfo)/ default preparationreturn DoPreparePrinting(pInfo);void CMyView:OnBeginPrinting(CDC* /*pDC*/,
13、CPrintInfo* /*pInfo*/)/ TODO: add extra initialization before printingvoid CMyView:OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)/ TODO: add cleanup after printing/ CMyView diagnostics#ifdef _DEBUGvoid CMyView:AssertValid() constCRecordView:AssertValid();void CMyView:Dump(CDumpContext& dc) c
14、onstCRecordView:Dump(dc);CMyDoc* CMyView:GetDocument() / non-debug version is inlineASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CMyDoc);return (CMyDoc*)m_pDocument;#endif /_DEBUG/ CMyView database supportCRecordset* CMyView:OnGetRecordset()return m_pSet;/ CMyView message handlersvoid CMyView:OnBut
15、tonAdd() / TODO: Add your control notification handler code here/*m_pSet->AddNew();m_pSet->Update();/更新記錄集m_pSet->Requery();/重新提取數(shù)據(jù)m_pSet->MoveLast();/移動(dòng)下一條記錄UpdateData(FALSE);/更新視圖*/tryCDlgAdd DlgAdd;if()=IDOK)/"模式窗口方式打開,結(jié)束前不能操縱父窗口"m_pSet->AddNew();m_pSet->m_zgbh=;m_pSet
16、->m_zgxm=;m_pSet->m_zgnl=;m_pSet->m_zgxb=;m_pSet->m_zc=;m_pSet->m_szbm=;m_pSet->m_jbgz=;m_pSet->m_gzsj=;m_pSet->m_jl=;m_pSet->Update();/更新記錄集m_pSet->Requery();/重新提取記錄集m_pSet->MoveLast();/移動(dòng)下一條記錄UpdateData(FALSE);/更新視圖catch (CDBException* e)MessageBox(e->m_strError
17、);/對(duì)于異常信息的處理,這里是簡(jiǎn)單的輸出錯(cuò)誤的信息void CMyView:OnButtonDel() / TODO: Add your control notification handler code herem_pSet->Delete();m_pSet->MoveNext();if(m_pSet->IsEOF()m_pSet->MoveLast();if(m_pSet->IsBOF()m_pSet->SetFieldNull(NULL);UpdateData(FALSE);void CMyView:OnButtonFilter() / TODO: Add your control notification handler code hereCDlgQuery Dlgquery;CString value;if()=IDOK)/"模式窗口方式打開,結(jié)束前不能操縱父窗口"value="職工編
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025版?zhèn)€人車輛抵押債權(quán)債務(wù)處理執(zhí)行協(xié)議3篇
- 2025年度個(gè)人新能源汽車充電站場(chǎng)地承包協(xié)議2篇
- 2025版新能源汽車電池委托加工合同范本3篇
- 2025-2030全球眼科手術(shù)剪行業(yè)調(diào)研及趨勢(shì)分析報(bào)告
- 2025年全球及中國公共交流充電站行業(yè)頭部企業(yè)市場(chǎng)占有率及排名調(diào)研報(bào)告
- 2025年全球及中國碳納米管微球行業(yè)頭部企業(yè)市場(chǎng)占有率及排名調(diào)研報(bào)告
- 2025-2030全球汽車燃油回流管路行業(yè)調(diào)研及趨勢(shì)分析報(bào)告
- 二樓商業(yè)租賃專項(xiàng)協(xié)議(2024版)版
- 二零二五年度車輛牌照租賃市場(chǎng)拓展與合作開發(fā)合同4篇
- 二零二五年度車牌租賃與廣告合作協(xié)議3篇
- 二零二五年度無人駕駛車輛測(cè)試合同免責(zé)協(xié)議書
- 2025年湖北華中科技大學(xué)招聘實(shí)驗(yàn)技術(shù)人員52名歷年高頻重點(diǎn)提升(共500題)附帶答案詳解
- 黑龍江省哈爾濱市2024屆中考數(shù)學(xué)試卷(含答案)
- 高三日語一輪復(fù)習(xí)助詞「と」的用法課件
- 毛渣采購合同范例
- 無子女離婚協(xié)議書范文百度網(wǎng)盤
- 2023中華護(hù)理學(xué)會(huì)團(tuán)體標(biāo)準(zhǔn)-注射相關(guān)感染預(yù)防與控制
- 一年級(jí)數(shù)學(xué)個(gè)位數(shù)加減法口算練習(xí)題大全(連加法-連減法-連加減法直接打印版)
- 五年級(jí)上冊(cè)小數(shù)遞等式計(jì)算200道及答案
- 2024年廣東高考政治真題考點(diǎn)分布匯 總- 高考政治一輪復(fù)習(xí)
- 冀教版五年級(jí)下冊(cè)數(shù)學(xué)全冊(cè)教學(xué)課件
評(píng)論
0/150
提交評(píng)論