服裝倉儲貨品管理技巧
談倉庫貨品管理技巧
從多年倉庫管理實際操作經(jīng)驗中提取,以某品牌服裝物流倉庫管理為例。總結(jié)相關(guān)要點,共同學習分享:
一,影響倉儲貨品管理難度的因素有:貨品種類(指在庫貨品的SKU數(shù),如以型號或編號出現(xiàn),有一個數(shù)字或字母不同,即為不同的貨品,種類越多越難管理。)、貨品形狀(形狀不規(guī)則的貨品比形狀規(guī)則的貨品難管理,一個貨品沒有一個標準的長寬高即為不規(guī)則貨品。)、貨品重量(從搬運角度出發(fā),越重的貨品需要借助搬運機械,同時重貨對堆高有影響。)、貨品體積(過小易丟失,過大占空間,也影響搬運。)、貨品溫濕度存放要求(要求高的,管理難度越高,如服裝中的掛裝比普通服裝難管理)、貨品發(fā)貨規(guī)律性(有規(guī)律的好管理,無規(guī)律的難管理)。
所以管理一個倉庫,必須分析清楚存放貨品的特性。
二,如何提高出入庫效率和準確率:(以某品牌服裝倉庫管理為例。)1,學會分類,找到規(guī)律;
就服裝而言,首先可分為:上裝和下裝。按季節(jié)分為:春、夏、秋、冬裝。根據(jù)裝箱規(guī)格,分為薄、厚;根據(jù)庫存量,可分為:多、中、少。根據(jù)服裝是否帶配件,又可分為:有、無附件。按照種類又可分為:T恤、襯衫、牛仔、毛衣、裙子、西裝、吊帶背心等。按照價值,又可分為:高、中、低價。
分類之后,你才可以分析不同衣服的發(fā)貨特點,從中找到規(guī)律,當然這離不開數(shù)據(jù)的統(tǒng)計。什么時間段什么衣服到貨量較大,全年哪個種類的衣服發(fā)貨量最大(發(fā)貨量大的貨品可以考慮專區(qū)管理),不同的衣服包裝是否有不同的要求,庫存量大的發(fā)貨量就大,高價貨品要重點管理。
說明一下:此品牌服裝上衣和下衣大多是六個型號:XS(特小號)、S(小號)、M(中號)、L(大號)、XL(加大號)、XXL(加加大號),其中M號發(fā)貨量最大,XXL號很少。衣服首先分品牌,再分年份,再分季節(jié),再分大類,再分款,再分顏色,然后再分型號。
2,理清以往存在的問題和難點
由于此品牌服裝種類多,達5000多種,以往同類倉庫管理中經(jīng)常容易出現(xiàn)庫存只有一兩件的衣服找不到,或者配錯類似型號或顏色的衣服,同箱內(nèi)出現(xiàn)不同的衣服等。
難點:看似相同,其實不同。庫存小的衣服,一旦混到其它衣服中就找不到。高價衣服一旦缺少,損失嚴重。效率不高影響發(fā)貨,找不到衣服客戶會投訴,衣服少了,不好交待。所以要解決這些問題我就考慮到整零箱分開管理,分類分區(qū)管理(高價專區(qū)),定量定區(qū)管理,XL、XXL集中管理的方案。難點解決了,什么都好解決。
3,減少行走路徑
這是倉庫管理的原則,通過分類,可以把同類衣服集中管理,出單時同一張單據(jù)種類不要過多。新品入庫后,急于上店,要貨多,所以新品要放在最近的位置。
4,容積率和工作效率找到平衡點
倉庫空間是有限的,在有限的空間存放更多種類的衣服,更大量的衣服,提高容積率,有利于節(jié)約倉儲成本。但一味的提高容積率可能會影響發(fā)貨效率,所以要找到一個平衡點。我在管理過程中,把貨品分成幾類存放,主要以同款同色貨品的在庫量劃分,因為在庫量越大,意味著發(fā)貨量就大,反之庫存量只有幾件的時候,就很少發(fā),或不再需要發(fā)了。
貨量大的衣服,一天有好多個地區(qū)要配發(fā),以往每配發(fā)一次就要有一次搬箱和開箱的動作,且由于要貨量多,需拆掉許多的箱子。
舉個例:一種衣服每箱裝30件,以單個型號為例,當天有10個地區(qū)需要發(fā),需要的數(shù)量通常不是30的倍數(shù),數(shù)量不等,多少不一。如果是30的倍數(shù),發(fā)貨自然非常簡便。地區(qū)定量零頭廣州南通3551515寧波1818蘇州1212杭州4010上海4515廈門2525晉江1010合肥泰州8899零頭合計:127
從表中可以看出,每個地區(qū)都需要零頭,每取一次都要搬動零箱一次,從數(shù)量上來看,需要拆掉5個原箱。這個時候要提高效率就是要減少搬運次數(shù),減少開箱的動作。于是思考出:B敞口箱式:適用于剛?cè)霂烊∝涱l率較多的貨品,優(yōu)點是配貨便捷,缺點是如果是平面?zhèn)}庫會占用空間,如果有貨架,至于貨架底層即不浪費空間,也不影響取貨,如下圖:
從上圖看出,箱子的口是敞開的,而且型號從小到大排序。把貨品倒入這些箱子,以后配貨時就不再需要搬箱和開箱的動作,自然提高了配貨速度。C二垛式(是沒有貨架的情況下就地堆碼)或(貨架式):6種型號二垛堆碼,適用于發(fā)貨頻率適中的貨品,較節(jié)約空間,配貨也較方便,這適合貨品大量發(fā)貨之后,庫存量不多,以后很少發(fā)。在沒有貨架的時候碼在地上,空間要比敞口箱節(jié)約,但每次需要搬運和開箱動作。當然有貨架后,可以一層一個型號,最好是從小到大按序放置,這樣方便取貨,且不易出錯;
D集中堆碼式:所有型號堆成一垛,適用于貨品量較少,只有少數(shù)城市配發(fā),優(yōu)點是節(jié)約空間(這是在沒有貨架的情況下使用,如下圖):
單款拼箱式:當單個顏色所有型號總量低于60件(季節(jié)不同參數(shù)不同)時,此時貨品很少發(fā)貨或不發(fā)貨,幾個型號拼到一箱中,每種貨品可以節(jié)約3-4箱的空間;
多款拼箱建立箱號:每種貨品總量低于10件,此時可將多款貨品拼到1箱中,大大的節(jié)約了空間,為了找貨方便,可在箱上建行編號,同時也可在箱外貼上明細,當然在系統(tǒng)或電子帳上要詳細記錄。
(由于一箱內(nèi)裝幾種衣服,為了便于區(qū)分,做出了四格箱,即一個箱子里面有4個格子,一個格子里面放一種衣服,這樣衣服就方便區(qū)分,也不容易扯到一起。)
5,力求最短的找貨時間和取貨時間
影響出貨效率的第一因素就是能否在第一時間找到要出的貨。所以貨品的庫位必須準確詳細清楚,具體到點。舉個簡單的例子,現(xiàn)在讓你去給“某某人”送一封信,必須告訴你地址,具體的:省、市(縣)、鎮(zhèn)、街道。就這些信息你可以第一時間找到“某某人”所在的街道,但你不知門牌號,一看這條街道有1000個門牌號。好,如果告訴你門牌號是100號,好,找到了,一看,是幢40層的大廈。那你往哪層送?好,告訴你在10層,好,找到了,一看10層有二十個房間。我舉這個例子,就是說,庫位要詳細,告訴你在哪一排不行,還要知道在哪一格,知道哪一格不行,還要知道是哪一層。找的時間最耽誤時間。減少取貨時間,就是想方法減少搬運和開箱的時間,比如敞口箱就是減少了搬運和開箱動作。利用貨架,就像抽屜一樣,也減少了搬運。同時,把經(jīng)常發(fā)的貨品放在貨架下面,不常發(fā)的放在上面。
6,力求最少的搬運次數(shù)
除了上述的幾點之外,要考慮有沒有不必要的環(huán)節(jié),尤其是需要搬運動作的環(huán)節(jié)。
7,最短的時間復核出差錯
人不可能不出錯,一旦出錯就需要復核,以判斷錯在哪里,從而保證發(fā)貨的準確率。而往往發(fā)現(xiàn)錯誤后復核是一個耽誤發(fā)貨時間的過程。所以要有一個復核流程,以在最短的時間確認錯與對。實際工作中,我?guī)状斡龅揭坏┏鲥e復核的時間比操作的時間還多。所以,有必要思考如何在最短的時間復核完成。
舉個例子,某張單據(jù)共要貨200件,配貨員配完后,對貨員(核對裝箱的人員)裝到最后第6箱時發(fā)現(xiàn)少1件編號是123456789的衣服,這種衣服共要10件,現(xiàn)在對下來只有9件,這個時候如何復核是配貨員配錯了,還是對貨員對錯了,是不是少1件呢?首先,要判斷123456789的這種衣服裝在了哪一箱或哪幾箱中?然后再把涉及的箱子開箱清點,清點的時候先確認該箱的總件數(shù)是否有差異,然后再核對123456789這種衣服的件數(shù)是否相符,最終確認是不是錯了。
這里要注意:1,如何知道123456789這種衣服裝在了哪一箱?2,如果每箱都有,意味著每箱都要復核,工作量就大。所以你就會要求對貨員同種衣服盡量裝在一箱,以減少復核工作。3,要根據(jù)配貨記錄和對貨記錄分析是不是有錯的可能:比如123456789這種衣服需要10件,從配貨記錄上看,10件是一次取完,還是兩次取完。比如說要10件,結(jié)果零箱里只有9件,配貨員會在單據(jù)上注明-1,結(jié)果配貨員忘記補了,這就很顯然是少配了一件。
8,能用電腦算的,不用人算
要熟練運用EXCEL,因為EXCEL可以通過數(shù)據(jù)透視,各種函數(shù)幫你進行統(tǒng)計和計算,在最短的時間里得到你想要的數(shù)據(jù),極大的提供了工作效率。
9,能打印的不手填
許多單據(jù),盡量統(tǒng)一標準格式,打印比手填清晰規(guī)范。
10,最短的盤點時間
同一貨品盡量集中,同一貨品保持唯一的零箱,比如說某一貨品庫存215件,裝箱規(guī)格30件一箱,理論就是30×7+5=215,7個整箱,1個零箱。結(jié)果點出來10箱,因為零箱有幾個,這就增加了盤點的時間。所以在庫貨品盡量整、零箱分開管理,整箱區(qū)不允許存在零箱,零箱區(qū)一個型號的零箱保持唯一。
11,最易區(qū)別的標識
外箱上的顏色、型號以及編號要便于區(qū)分,比如說123456789與122457689,如果書寫成:123.456.789與122.457.689,讓人一看就不一樣。
12,學會編號
對庫位要合理編號,這關(guān)系到系統(tǒng)打印單據(jù)時的排序順序,盡量減少配貨員的迂回作業(yè)。同時編號合理便于統(tǒng)計。編號要便于區(qū)別,從發(fā)音和字形上也要考慮好。在年中和年末盤點時,對在庫貨品需要全盤,而這個時候每一箱貨都需要一個號碼,編號是否合理,不僅影響貼號時間、盤點時間、以及復核時間,還影響到盤點后接下來整理與發(fā)貨的時間。
13,定期與定時整理
貨品是流動性的,總是從多到少,直至沒有的過程。新品入庫后置于敞口箱,當發(fā)到一定剩余量時就需要移到貨架上去,再少就需要進行拼箱以節(jié)約空間了,這通常是一周一次,文員需要把數(shù)據(jù)統(tǒng)計出來,看哪些貨需要移了,哪些貨需要拼箱了,要有足夠的敞口箱庫位留給新入庫的貨品。
為檢查文員錄入工作的準確性,也要定時核對庫位的準確性,以免在需要貨品的時候找不到需要的貨。
14,能平時做的不到戰(zhàn)時做
大家都逛過超市,如果你要購買的東西在陳列的地方?jīng)]有了,服務(wù)員還要到倉庫去拿,這就可能耽誤你的時間,一件商品,如果暢銷,陳列的地方就要有足夠多的量。所以說我們的準備工作要做充分,要事先檢查零箱區(qū)是否缺型號,敞口箱里是不是需要補些衣服過來,以免“斷糧”,把一些工作提前做掉。每天發(fā)貨時封箱的工作量也很大,在沒有單據(jù)時我們可以先把箱子準備好,封好,用的時候直接用就可以了。
15,利用顏色管理
5S現(xiàn)場管理中,講顏色管理。庫房也是一樣,可以通過不同顏色的標識區(qū)分不同的區(qū)域、不同品牌的貨品、不同性質(zhì)的貨品、不同種類的貨品、不同型號的貨品,以達到方便區(qū)分的作用。
16,動態(tài)盤點
倉庫管理,講效率更講準確率。少貨是倉庫管理最忌諱的事。動態(tài)盤點有利于在第一時間發(fā)現(xiàn)問題,解決問題,消滅事故的萌芽。
對有些倉庫而言,當天入庫的貨品和當天有發(fā)貨記錄的貨品,在庫量都需要進行一次盤點,以確保庫存的準確性。而服裝每天發(fā)貨品種有幾百個SKU,這樣盤點工作量就非常大,那就對一些高價值的貨品,或當天有過差異的貨品(即配貨量與對貨量不致的貨品)進行盤點。動態(tài)盤點有幾點好處:一是對入庫的貨品確定庫位是否正確,比如說一款貨品,入庫記錄在A0101位置,結(jié)果文員錄入時錄成了A0401位置,如果當天盤點就能發(fā)現(xiàn)是文員的錯誤,以免在以后配這款貨的時候配貨員在A0401這個位置找個半天也找不到。二是對有差異貨品進行確認,某種衣服當日期初108件,今天發(fā)了12個地區(qū),共發(fā)走78件,那么庫里面還有30件,如果盤點發(fā)現(xiàn)不是30,那么這就時候就要去分析哪個地區(qū)多發(fā)了還是少發(fā)了,第一時間查出原因解決掉。如果是多發(fā),那么庫房就少貨,如果少發(fā),那么客戶就會投訴。當天的問題不發(fā)現(xiàn)不解決,過后很難找到原因,也就很難解決。
17,故意事先設(shè)錯法提高工作質(zhì)量
員工工作長時間不出錯是容易麻痹的,且有些對貨員明明發(fā)現(xiàn)配貨員配錯衣服不記錄不復核,這樣就有可能在真正出現(xiàn)了錯誤的時候沒有發(fā)現(xiàn),導致錯發(fā)衣服。為了檢查及提醒工作人員的責任心,管理者不僅要對現(xiàn)場操作人員經(jīng)常性的檢查,比如說對貨員用盤點機掃描時要一邊掃描一邊數(shù)數(shù),檢查人員可以突然打斷,在對貨員不看盤點機的情況下,讓他報出多少件,如果報不出,或是不對,說明沒有按要求操作。故意事先設(shè)錯,就是事先設(shè)置一個錯誤的問題,比如說多放一件衣服,或拿走一件衣服,看對貨員能不能發(fā)現(xiàn),以及有沒有按要求記錄、復核。因為如果不記錄,就沒有復核,同時當天也不會有動態(tài)盤點,種種的細節(jié)不注意就會導致問題的發(fā)生。記錄非常重要,因為這些都是憑證。當你發(fā)現(xiàn)有些對貨員該記錄沒有記錄時就要批評指出,并強調(diào)不記錄被發(fā)現(xiàn)有所懲罰時,定會認真執(zhí)行。時刻注意培養(yǎng)員工好的習慣。
18,堅持以人為本庫房里每個崗位,配貨員、對貨員以及收貨員在入庫清點貨品時,都要考慮節(jié)省每一個彎腰、開箱和搬運動作,能一次完成的動作,盡量不重復完成,能同時完成的動作,不分開完成。任何好的方法都是許多次試驗之后得出來的。有時候我也想像出許多看似好的方法,結(jié)果實操時并不那么理想,所以任何時候都要與實際操作相結(jié)合,減少操作人員等的時間,想的時間,算的時間,以及不必要的復核時間。
擴展閱讀:倉庫貨品管理說明書
目錄
摘要......................................................................................................................1前言......................................................................................................................2正文......................................................................................................................31.2.3.4.5.6.
采用類C語言定義相關(guān)的數(shù)據(jù)類型..........................................................3各模塊的偽碼算法......................................................................................3函數(shù)的調(diào)用關(guān)系圖......................................................................................8調(diào)試分析......................................................................................................9測試結(jié)果....................................................................................................10源程序(帶注釋)...................................................................................113
總結(jié)....................................................................................................................19參考文獻................................................................................................................21致謝....................................................................................................................22附件Ⅰ部分源程序代碼......................................................................................23
摘要
庫存管理系統(tǒng)是典型的信息管理系統(tǒng)(MIS),其開發(fā)主要包括后臺數(shù)據(jù)庫的建立和維護以及前端應(yīng)用程序的開發(fā)兩個方面。對于前者要求建立起一個數(shù)據(jù)一致性和完整性強、數(shù)據(jù)安全性好的庫;而對于后者則要求應(yīng)用程序具有功能完備、易使用等特點。
該程序?qū)崿F(xiàn)庫存貨品信息的輸入、插入、刪除、查找等功能,并能建立和更新的庫存信息保存于文件供輸出或打印。對于查找、刪除等功能要求能按貨品名、貨品號分別進行。每個貨品的相關(guān)信息包括:貨品號、貨品名、貨品庫存量、進貨日期、貨品生產(chǎn)廠家及供應(yīng)商等。
關(guān)鍵詞:庫存管理;面向?qū)ο;?shù)據(jù)庫
前言
隨著我國市場經(jīng)濟的蓬勃發(fā)展和人們對物質(zhì)水平需求的增加,各行各業(yè)都處于一個飛速發(fā)展的時期,行業(yè)的快速發(fā)展必然導致各企業(yè)之間的競爭更加激烈,為了使自己的企業(yè)在競爭中能夠站穩(wěn)腳跟,不被激烈的競爭環(huán)境所壓倒,必然要求企業(yè)加強對自身的管理,提高企業(yè)的經(jīng)營效率。
本文正文分為六部分,第一部分列舉了采用類c語言定義相關(guān)的數(shù)據(jù)類型,第二部分介紹各模塊的偽碼算法,第三部分繪出了函數(shù)的調(diào)用關(guān)系圖,第四部分簡述算法的調(diào)試分析,第五部分展示了系統(tǒng)的部分測試結(jié)果,第六部分附加了完整的源代碼(帶注釋)
本系統(tǒng)由于個人能力有限,設(shè)計過程中一定有很多不足之處,以求日后完善。
正文
1.采用類c語言定義相關(guān)的數(shù)據(jù)類型
structBrand{};
structTotal//該結(jié)構(gòu)只在統(tǒng)計商品總量時使用{};
inti;//商品編號
structToal*next;intBrand_number;charBrand_name[20];charProvide_name[20];intBrand_code;charProductor_name[20];structBrand*next;
2.模各塊的偽碼算法
1.貨品信息的輸入
#if!defined(AFX_INDLG_H__45EE16C9_7E05_4051_847B_E7EA39D86403__INCLUDED_)
#define
AFX_INDLG_H__45EE16C9_7E05_4051_847B_E7EA39D86403__INCLUDED_
#if_MSC_VER>1000#pragmaonce
#endif//_MSC_VER>1000
//InDlg.h:headerfile//
///////////////////////////////////////////////////////////////////////////////CInDlgdialog
classCInDlg:publicCDialog{
//Constructionpublic:
CInDlg(CWnd*pParent=NULL);//standardconstructor
//DialogData//{{AFX_DATA(CInDlg)
enum{IDD=IDD_DIALOG_IN};CComboBoxm_cbProvider;CComboBox
m_cbGoods;
CTimem_Date;CTimem_Time;CStringm_strNum;CStringm_strPrice;
//}}AFX_DATA
//Overrides//ClassWizardgeneratedvirtualfunctionoverrides//{{AFX_VIRTUAL(CInDlg)protected:
virtualvoidDoDataExchange(CDataExchange*pDX);support
//}}AFX_VIRTUAL
//Implementationprotected://Generatedmessagemapfunctions
//{{AFX_MSG(CInDlg)
4//DDX/DDV
virtualBOOLOnInitDialog();afx_msgvoidOnButtonOk();afx_msgvoidOnButtonCancel();//}}AFX_MSG
DECLARE_MESSAGE_MAP()
private:};
//{{AFX_INSERT_LOCATION}}
//MicrosoftVisualC++willinsertadditionaldeclarationsimmediatelybeforethepreviousline.
#endif
//!defined(AFX_INDLG_H__45EE16C9_7E05_4051_847B_E7EA39D86403__INCLUDED_)
2.貨品入庫操作(插入操作)voidCInDlg::AddGoods(intiNum){
intiCurrentNum=0;_variant_tHolder,strQuery;
voidAddIn(CStringstrGcode,CStringstrPcode);CStringm_strProviderName;CStringm_strGoodsName;voidAddGoods(intiNum);
voidGetProviderCode(CStringstrName,CString&strCode);voidGetGoodsCode(CStringstrName,CString&strCode);
strQuery="select*fromgoodswhereG_name=""+m_strGoodsName+""";
theApp.ADOExecute(theApp.m_pRs,strQuery);theApp.m_pRs->MoveFirst();
Holder=theApp.m_pRs->GetCollect("Current_number");if(Holder.vt!=VT_NULL)
iCurrentNum=Holder.iVal;
iCurrentNum+=iNum;CStringstrSql;
strSql.Format("UPDATE
goods
SET
Current_number=%d
WHERE
G_name="%s"",iCurrentNum,m_strGoodsName);notificationhandlercodehere
}3.貨品的出庫操作(刪除操作)voidCOutDlg::DelGoods(intiNum){
intiCurrentNum=0;_variant_tHolder,strQuery;
_variant_tvtQuery(strSql);
//TODO:Addyourcontrol
if(theApp.ADOExecute(theApp.m_pRs,vtQuery)){}
AfxMessageBox("入庫成功");theApp.m_log.AddLog("商品入庫");
strQuery="select*fromgoodswhereG_name=""+m_strGoodsName+""";
strSql.Format("UPDATE
goods
SET
6theApp.ADOExecute(theApp.m_pRs,strQuery);
theApp.m_pRs->MoveFirst();
Holder=theApp.m_pRs->GetCollect("Current_number");if(Holder.vt!=VT_NULL)
iCurrentNum=Holder.iVal;
iCurrentNum-=iNum;
CStringstrSql;
Current_number=%dWHERE
G_name="%s"",iCurrentNum,m_strGoodsName);notificationhandlercodehere}
4.貨品查找操作
voidCViewDlg::ViewGoods(){
m_listDisp.DeleteAllItems();m_listDisp.SetRedraw(FALSE);
_variant_tHolder,strQuery;_variant_tvtQuery(strSql);
if(theApp.ADOExecute(theApp.m_pRs,vtQuery)){}
AfxMessageBox("出庫成功");theApp.m_log.AddLog("商品出庫");
//TODO:Addyourcontrol
strQuery="select*fromgoods";
theApp.ADOExecute(theApp.m_pRs,strQuery);
intiCount=theApp.m_pRs->GetRecordCount();
7if(0==iCount)
return;
theApp.m_pRs->MoveFirst();
inti=0;
while(!theApp.m_pRs->adoEOF){
Holder=theApp.m_pRs->GetCollect("G_code");if(Holder.vt!=VT_NULL)
m_listDisp.InsertItem(i,(char*)(_bstr_t)Holder);}
m_listDisp.SetRedraw(TRUE);
}m_strNum.Format("%d",iCount);theApp.m_pRs->MoveNext();i++;
Holder=theApp.m_pRs->GetCollect("Min_number");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,4,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Current_number");if(Holder.vt!=VT_NULL)
Holder=theApp.m_pRs->GetCollect("Max_number");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,3,(char*)(_bstr_t)Holder);m_listDisp.SetItemText(i,2,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("G_name");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,1,(char*)(_bstr_t)Holder);
3.函數(shù)的調(diào)用關(guān)系圖
庫存管理系統(tǒng)系統(tǒng)管理進貨管理出貨管理報表統(tǒng)計信息查詢身份驗證注冊用戶修改刪除用戶修改密碼出庫單填寫獲取采購員信息日月報表報表入庫單填寫填寫貨品信息修改最低庫存貨品查詢庫存查詢報表查詢
4.調(diào)試分析
a,調(diào)試中遇到的問題及對問題的解決方法
調(diào)試中出現(xiàn)無法編譯的情況,經(jīng)檢原因為查代碼寫錯,以及各函數(shù)的調(diào)用之間產(chǎn)生矛盾等等問題,最后經(jīng)老師和同學的幫助找出問題所在,加以改正,最終的是到一個較完整的程序。
b,算法的時間復雜度和空間復雜度時間復雜度為O(n)空間復雜度為S(n)
5.測試結(jié)果
1.登陸界面
2.主界面
3.商品入庫
4.商品出庫
5.入庫信息
6.商品信息
6.源程序(帶注釋)
//AlertDlg.cpp:implementationfile
#include"stdafx.h"#include"GMS.h"#include"AlertDlg.h"
#ifdef_DEBUG
#definenewDEBUG_NEW#undefTHIS_FILE
staticcharTHIS_FILE[]=__FILE__;#endif
///////////////////////////////////////////////////////////////////////////////CAlertDlgdialog
CAlertDlg::CAlertDlg(CWnd*pParent/*=NULL*/){}
voidCAlertDlg::DoDataExchange(CDataExchange*pDX){
CDialog::DoDataExchange(pDX);
13:CDialog(CAlertDlg::IDD,pParent)
//{{AFX_DATA_INIT(CAlertDlg)
//NOTE:theClassWizardwilladdmemberinitializationhere
//}}AFX_DATA_INIT}
BEGIN_MESSAGE_MAP(CAlertDlg,CDialog)
//{{AFX_MSG_MAP(CAlertDlg)
ON_BN_CLICKED(IDC_BUTTON_OK,OnButtonOk)//}}AFX_MSG_MAP
//{{AFX_DATA_MAP(CAlertDlg)
DDX_Control(pDX,IDC_LIST_LOWDISP,m_listLowDisp);DDX_Control(pDX,IDC_LIST_HIGHDISP,m_listHighDisp);//}}AFX_DATA_MAP
END_MESSAGE_MAP()
///////////////////////////////////////////////////////////////////////////////CAlertDlgmessagehandlers
voidCAlertDlg::OnButtonOk(){}
BOOLCAlertDlg::OnInitDialog(){
CDialog::OnInitDialog();
m_listLowDisp.InsertColumn(0,"商品編號");m_listLowDisp.InsertColumn(1,"商品名稱");m_listLowDisp.InsertColumn(2,"當前庫存");
14OnOK();
//TODO:Addyourcontrolnotificationhandlercodehere
RECTrect;intwid;
RefreshData();
15m_listLowDisp.InsertColumn(3,"最大庫容");m_listLowDisp.InsertColumn(4,"最小庫容");
m_listLowDisp.GetWindowRect(&rect);wid=rect.right-rect.left;
m_listLowDisp.SetColumnWidth(0,wid/5);m_listLowDisp.SetColumnWidth(1,wid/5);m_listLowDisp.SetColumnWidth(2,wid/5);m_listLowDisp.SetColumnWidth(3,wid/5);m_listLowDisp.SetColumnWidth(4,wid/5);
m_listLowDisp.SetExtendedStyle(LVS_EX_FULLROWSELECT);
m_listHighDisp.InsertColumn(0,"商品編號");m_listHighDisp.InsertColumn(1,"商品名稱");m_listHighDisp.InsertColumn(2,"當前庫存");m_listHighDisp.InsertColumn(3,"最大庫容");m_listHighDisp.InsertColumn(4,"最小庫容");
m_listHighDisp.GetWindowRect(&rect);wid=rect.right-rect.left;
m_listHighDisp.SetColumnWidth(0,wid/5);m_listHighDisp.SetColumnWidth(1,wid/5);m_listHighDisp.SetColumnWidth(2,wid/5);m_listHighDisp.SetColumnWidth(3,wid/5);m_listHighDisp.SetColumnWidth(4,wid/5);
m_listHighDisp.SetExtendedStyle(LVS_EX_FULLROWSELECT);}
voidCAlertDlg::RefreshData(){
m_listLowDisp.DeleteAllItems();m_listLowDisp.SetRedraw(FALSE);
_variant_tHolder,strQuery;
//TODO:Addextrainitializationhere
returnTRUE;//returnTRUEunlessyousetthefocustoacontrol//EXCEPTION:OCXPropertyPagesshouldreturnFALSE
strQuery="select*fromgoodswhereCurrent_number//高于
strQuery="select*fromgoodswhereCurrent_number>=Max_number";
theApp.ADOExecute(theApp.m_pRs,strQuery);m_listHighDisp.DeleteAllItems();m_listHighDisp.SetRedraw(FALSE);
m_listLowDisp.SetRedraw(TRUE);
}theApp.m_pRs->MoveNext();i++;
Holder=theApp.m_pRs->GetCollect("Min_number");if(Holder.vt!=VT_NULL)
m_listLowDisp.SetItemText(i,4,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Current_number");if(Holder.vt!=VT_NULL)
Holder=theApp.m_pRs->GetCollect("Max_number");if(Holder.vt!=VT_NULL)
m_listLowDisp.SetItemText(i,3,(char*)(_bstr_t)Holder);m_listLowDisp.SetItemText(i,2,(char*)(_bstr_t)Holder);
if(Holder.vt!=VT_NULL)
m_listLowDisp.SetItemText(i,1,(char*)(_bstr_t)Holder);
iCount=theApp.m_pRs->GetRecordCount();
18if(0==iCount)
return;
theApp.m_pRs->MoveFirst();
i=0;
while(!theApp.m_pRs->adoEOF){
Holder=theApp.m_pRs->GetCollect("G_code");if(Holder.vt!=VT_NULL)
m_listHighDisp.InsertItem(i,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("G_name");if(Holder.vt!=VT_NULL)
m_listHighDisp.SetItemText(i,1,(char*)(_bstr_t)Holder);
}Holder=theApp.m_pRs->GetCollect("Current_number");if(Holder.vt!=VT_NULL)
Holder=theApp.m_pRs->GetCollect("Max_number");if(Holder.vt!=VT_NULL)
m_listHighDisp.SetItemText(i,3,(char*)(_bstr_t)Holder);m_listHighDisp.SetItemText(i,2,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Min_number");if(Holder.vt!=VT_NULL)
m_listHighDisp.SetItemText(i,4,(char*)(_bstr_t)Holder);
theApp.m_pRs->MoveNext();i++;
m_listHighDisp.SetRedraw(TRUE);
總結(jié)
這學期已接近尾聲,它對我所產(chǎn)生的影響卻是巨大的。作為計算機科學與技術(shù)專業(yè)的學生,這段時間的學習過程讓我們學到了很多知識,然而真正運用于實踐的并不多,放假前的這次課程設(shè)計恰是對我們過去兩年所學的一次總結(jié),我們可以在老師的幫助下自己來嘗試開發(fā)一個小型項目,把所學的單純的理論知識變成為實際的操作經(jīng)驗,而不再是眼高手低。
此次庫存管理系統(tǒng)開發(fā)讓我學習到很多知識,現(xiàn)總結(jié)如下:
系統(tǒng)開發(fā)的過程中,我深刻體會到了以前上課老師經(jīng)常提起的一個問題,那就是:一個系統(tǒng)開發(fā)的過程中編碼不是最重要的,重要的是對系統(tǒng)進行分析以及建立恰當?shù)南到y(tǒng)模型。有了一個好的系統(tǒng)模型之后,我們再將其劃分成幾個模塊,那樣做起來就會容易得多。本系統(tǒng)中采用了生命周期法進行系統(tǒng)的開發(fā),就體現(xiàn)了該模塊化設(shè)計思想。
在該庫存管理系統(tǒng)設(shè)計中,從系統(tǒng)的實用性出發(fā),我能夠在開發(fā)該系統(tǒng)時站在用戶的角度看問題,本著用戶操作界面友好、清晰、易學易用的原則進行設(shè)計。如開發(fā)過程中我盡可能地設(shè)想記錄為空,輸入為空,輸入出錯等邊界條件,然后在這些邊界上,設(shè)置出錯檢測,使系統(tǒng)能自動捕獲出錯點,給出提示,允許用戶重新進行操作,使系統(tǒng)能夠安全的運行下去,而不是退出系統(tǒng)。
文章的前面講到了本系統(tǒng)數(shù)據(jù)庫是使用SQLServer201*進行設(shè)置的,也講到了它的優(yōu)點,這里就不多說了,但是在本次設(shè)計中,我發(fā)現(xiàn)了VisualC#的一種應(yīng)用編程接口ADO(ActiveXDataObjects)。它是一種面向?qū)ο蟮摹⑴c語言無關(guān)的應(yīng)用編程接口,具有易于使用、高速度、低內(nèi)存支出和占用磁盤較少,可以使用所有支持ODBC的數(shù)據(jù)庫等優(yōu)點;使用ADO可以實現(xiàn)動態(tài)數(shù)據(jù)庫的鏈接,從而避免以往靜態(tài)方式連接數(shù)據(jù)庫的一些缺點。這些知識對我本次的系統(tǒng)開發(fā)有著很大的幫助。
開發(fā)期間,我學會了有目的的去學習一些將要用到的東西,仔細地考慮工作流程的規(guī)律和步驟,充分利用手中的開發(fā)工具,利用其所具備的功能,盡量使自己的開發(fā)在代碼上實現(xiàn)少而精確、讓用戶能夠盡量簡單地進行操作。但是在檢測過程中,還是出現(xiàn)了很多的不足之處,這些都是要在今后的工作中需要努力改進和完善的。
在這次畢業(yè)設(shè)計中,我遇到了很多困難,這主要是由于我開發(fā)軟件的經(jīng)驗不足,工具的應(yīng)用也不夠熟練,雖然VisualC#.NET用的語言是C#,但是由于以前基礎(chǔ)不夠扎實,對我來說可以算是一個全新的嘗試,整個開發(fā)過程并不是很順利,卻使我從中充分體會到學習的快樂,系統(tǒng)也在從理論到實踐,再從實踐到理論的反復中一步步得到完善。
雖然,這次系統(tǒng)開發(fā)由于個人水平及時間有限等原因,只能完成一些基本的功能,程序代碼不夠簡練,好多設(shè)想也未能得到實現(xiàn),這不能不說是個很大的遺憾。現(xiàn)有系統(tǒng)還存在著以下問題:第一點,不能實現(xiàn)界面動態(tài)轉(zhuǎn)換功能。由于技術(shù)原因,我只能用Panel控件實現(xiàn)靜態(tài)的界面轉(zhuǎn)換;第二點,功能模塊不夠全面。作為庫存管理系統(tǒng),系統(tǒng)設(shè)計中還能加上備品備件管理和系統(tǒng)維護等功能模塊,可是由于時間比較緊迫,該想法未能實施。由于我第一次開發(fā)一個完整的數(shù)據(jù)庫管理系統(tǒng),不足之處在所難免,敬請各位老師、領(lǐng)導批評指正,我會在以后的工作中加以完善和改進。
總之,這次的系統(tǒng)開發(fā),實現(xiàn)了我自己動手完成一個系統(tǒng)開發(fā)的目標,也學習到很多東西,不只是實踐經(jīng)驗,還有一些做事的道理:在工作時,要盡量把要遇到的問題考慮周全,提前做好準備,那樣就不會在遇到問題時有措手不及的感覺;做事一定要不斷地去嘗試,然后盡自己最大的努力去完成它,人的發(fā)展?jié)摿κ蔷薮蟮,不要一開始就否定自己,低估自己,雖然不能說只要努力就會取得成功,但是如果不努力,就永遠不會成功。
參考文獻
1嚴蔚敏,吳偉民.《數(shù)據(jù)結(jié)構(gòu)(C語言版)》.清華大學出版社.
2嚴蔚敏,吳偉民.《數(shù)據(jù)結(jié)構(gòu)題集(C語言版)》.清華大學出版社.3《DATASTRUCTUREWITHC++》.WilliamFord,WilliamTopp.清華大學出版社(影印版).
4譚浩強.《c語言程序設(shè)計》.清華大學出版社.
5.數(shù)據(jù)結(jié)構(gòu)與算法分析(Java版),APracticalIntroductiontoDataStructuresandAlgorithmAnalysisJavaEditionCliffordA.Shaffer,張銘,劉曉丹譯電子工業(yè)出版社201*年1月
致謝
在本次課程設(shè)計中,我要特別感謝我的指導老師王旭陽,從她身上我學到了很多東西。王老師認真負責的工作態(tài)度,嚴謹?shù)闹螌W精神都使我受益匪淺。她無論在理論上還是在實踐中,都給予我很大的幫助,幫助我解決了不少的難點,使得系統(tǒng)能夠逐步完善,我也從中得到不少提高,對我以后的工作和學習都有著巨大的幫助,感謝她耐心的輔導并表示衷心的感謝!
此外,還要對那些在我系統(tǒng)開發(fā)過程中幫助過我的同學一并表示衷心的感謝!
附件Ⅰ部分源程序代碼
//ViewDlg.cpp:implementationfile//
#include"stdafx.h"#include"GMS.h"#include"ViewDlg.h"
#ifdef_DEBUG
#definenewDEBUG_NEW#undefTHIS_FILE
staticcharTHIS_FILE[]=__FILE__;#endif
///////////////////////////////////////////////////////////////////////////////CViewDlgdialog
CViewDlg::CViewDlg(CWnd*pParent/*=NULL*/){}
voidCViewDlg::DoDataExchange(CDataExchange*pDX)
23:CDialog(CViewDlg::IDD,pParent)
//{{AFX_DATA_INIT(CViewDlg)m_strNum=_T("");//}}AFX_DATA_INIT{}
BEGIN_MESSAGE_MAP(CViewDlg,CDialog)
//{{AFX_MSG_MAP(CViewDlg)
ON_BN_CLICKED(IDC_BUTTON_OK,OnButtonOk)//}}AFX_MSG_MAP
CDialog::DoDataExchange(pDX);//{{AFX_DATA_MAP(CViewDlg)
DDX_Control(pDX,IDC_LIST_DISP,m_listDisp);DDX_Text(pDX,IDC_EDIT_NUM,m_strNum);//}}AFX_DATA_MAP
END_MESSAGE_MAP()
///////////////////////////////////////////////////////////////////////////////CViewDlgmessagehandlers
voidCViewDlg::Init(intiKind){}
voidCViewDlg::SetTitle(){
switch(m_iKind){case1:
SetWindowText(_T("商品信息"));break;
24this->m_iKind=iKind;}
voidCViewDlg::SetStyle(){
RECTrect;intwid;switch(m_iKind){case1:
m_listDisp.InsertColumn(0,"商品編號");m_listDisp.InsertColumn(1,"商品名稱");m_listDisp.InsertColumn(2,"當前庫存");m_listDisp.InsertColumn(3,"最大庫容");m_listDisp.InsertColumn(4,"最小庫容");
25case2:
SetWindowText(_T("商家信息"));break;
case3:
SetWindowText(_T("入庫信息"));break;
case4:
SetWindowText(_T("出庫信息"));break;
case5:}
SetWindowText(_T("操作日志"));break;
m_listDisp.GetWindowRect(&rect);wid=rect.right-rect.left;
m_listDisp.SetColumnWidth(0,wid/6);m_listDisp.SetColumnWidth(1,wid/6);m_listDisp.SetColumnWidth(2,wid/6);m_listDisp.SetColumnWidth(3,wid/6);m_listDisp.SetColumnWidth(4,wid/6);m_listDisp.SetColumnWidth(5,wid/6);
m_listDisp.SetExtendedStyle(LVS_EX_FULLROWSELECT);
break;
m_listDisp.GetWindowRect(&rect);wid=rect.right-rect.left;
m_listDisp.SetColumnWidth(0,wid/5);m_listDisp.SetColumnWidth(1,wid/5);m_listDisp.SetColumnWidth(2,wid/5);m_listDisp.SetColumnWidth(3,wid/5);m_listDisp.SetColumnWidth(4,wid/5);
m_listDisp.SetExtendedStyle(LVS_EX_FULLROWSELECT);break;case2:
m_listDisp.InsertColumn(0,"商家編號");m_listDisp.InsertColumn(1,"商家名稱");m_listDisp.InsertColumn(2,"商家地址");m_listDisp.InsertColumn(3,"負責人");m_listDisp.InsertColumn(4,"電話");m_listDisp.InsertColumn(5,"Email");
case3:
m_listDisp.InsertColumn(0,"商品編號");
m_listDisp.GetWindowRect(&rect);wid=rect.right-rect.left;
m_listDisp.SetColumnWidth(0,wid/5);m_listDisp.SetColumnWidth(1,wid/5);m_listDisp.SetColumnWidth(2,wid/5);m_listDisp.SetColumnWidth(3,wid/5);m_listDisp.SetColumnWidth(4,wid/5);
27m_listDisp.InsertColumn(1,"商家編號");m_listDisp.InsertColumn(2,"入庫數(shù)量");m_listDisp.InsertColumn(3,"購入價格");m_listDisp.InsertColumn(4,"購入日期");
m_listDisp.GetWindowRect(&rect);wid=rect.right-rect.left;
m_listDisp.SetColumnWidth(0,wid/5);m_listDisp.SetColumnWidth(1,wid/5);m_listDisp.SetColumnWidth(2,wid/5);m_listDisp.SetColumnWidth(3,wid/5);m_listDisp.SetColumnWidth(4,wid/5);
m_listDisp.SetExtendedStyle(LVS_EX_FULLROWSELECT);
break;
case4:
m_listDisp.InsertColumn(0,"商品編號");m_listDisp.InsertColumn(1,"出庫數(shù)量");m_listDisp.InsertColumn(2,"庫存管理員");m_listDisp.InsertColumn(3,"出庫負責人");m_listDisp.InsertColumn(4,"出庫日期");}
voidCViewDlg::ViewGoods(){
m_listDisp.DeleteAllItems();m_listDisp.SetRedraw(FALSE);
_variant_tHolder,strQuery;}
m_listDisp.SetExtendedStyle(LVS_EX_FULLROWSELECT);break;case5:
m_listDisp.InsertColumn(0,"操作員");m_listDisp.InsertColumn(1,"事件");m_listDisp.InsertColumn(2,"時間");m_listDisp.GetWindowRect(&rect);wid=rect.right-rect.left;
m_listDisp.SetColumnWidth(0,wid/3);m_listDisp.SetColumnWidth(1,wid/3);m_listDisp.SetColumnWidth(2,wid/3);
strQuery="select*fromgoods";
theApp.ADOExecute(theApp.m_pRs,strQuery);
intiCount=theApp.m_pRs->GetRecordCount();
if(0==iCount)
return;
29theApp.m_pRs->MoveFirst();
inti=0;
while(!theApp.m_pRs->adoEOF){
Holder=theApp.m_pRs->GetCollect("G_code");if(Holder.vt!=VT_NULL)
m_listDisp.InsertItem(i,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("G_name");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,1,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Current_number");if(Holder.vt!=VT_NULL)
Holder=theApp.m_pRs->GetCollect("Max_number");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,3,(char*)(_bstr_t)Holder);m_listDisp.SetItemText(i,2,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Min_number");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,4,(char*)(_bstr_t)Holder);
}theApp.m_pRs->MoveNext();i++;
m_strNum.Format("%d",iCount);}
voidCViewDlg::ViewProvider(){
m_listDisp.DeleteAllItems();m_listDisp.SetRedraw(FALSE);
_variant_tHolder,strQuery;m_listDisp.SetRedraw(TRUE);
strQuery="select*fromprovider";
theApp.ADOExecute(theApp.m_pRs,strQuery);
intiCount=theApp.m_pRs->GetRecordCount();
Holder=theApp.m_pRs->GetCollect("Provider_address");if(Holder.vt!=VT_NULL)
30if(0==iCount)
return;
theApp.m_pRs->MoveFirst();
inti=0;
while(!theApp.m_pRs->adoEOF){
Holder=theApp.m_pRs->GetCollect("Provider_code");if(Holder.vt!=VT_NULL)
m_listDisp.InsertItem(i,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Provider_name");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,1,(char*)(_bstr_t)Holder);}
voidCViewDlg::ViewInlib(){
m_listDisp.DeleteAllItems();m_listDisp.SetRedraw(FALSE);
_variant_tHolder,strQuery;
31m_listDisp.SetItemText(i,2,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Provider_person");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,3,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Provider_telphone");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,4,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Provider_email");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,5,(char*)(_bstr_t)Holder);
}theApp.m_pRs->MoveNext();i++;
m_strNum.Format("%d",iCount);
m_listDisp.SetRedraw(TRUE);
strQuery="select*frominlib";
theApp.ADOExecute(theApp.m_pRs,strQuery);
intiCount=theApp.m_pRs->GetRecordCount();
32if(0==iCount)
return;
theApp.m_pRs->MoveFirst();
inti=0;
while(!theApp.m_pRs->adoEOF){
Holder=theApp.m_pRs->GetCollect("Goods_code");if(Holder.vt!=VT_NULL)
m_listDisp.InsertItem(i,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Provider_code");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,1,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("In_number");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,2,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("In_Price");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,3,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("In_Date");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,4,(char*)(_bstr_t)Holder);}
voidCViewDlg::ViewOutlib(){
m_listDisp.DeleteAllItems();m_listDisp.SetRedraw(FALSE);
_variant_tHolder,strQuery;m_listDisp.SetRedraw(TRUE);
}m_strNum.Format("%d",iCount);theApp.m_pRs->MoveNext();i++;
strQuery="select*frominlib";
theApp.ADOExecute(theApp.m_pRs,strQuery);
intiCount=theApp.m_pRs->GetRecordCount();
Holder=theApp.m_pRs->GetCollect("Out_number");
33if(0==iCount)
return;
theApp.m_pRs->MoveFirst();
inti=0;
while(!theApp.m_pRs->adoEOF){
Holder=theApp.m_pRs->GetCollect("Goods_code");if(Holder.vt!=VT_NULL)
m_listDisp.InsertItem(i,(char*)(_bstr_t)Holder);}
BOOLCViewDlg::OnInitDialog(){
CDialog::OnInitDialog();SetTitle();SetStyle();switch(m_iKind){case1:
ViewGoods();break;
34}if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,1,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Out_person");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,2,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("taker");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,3,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("Out_date");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,4,(char*)(_bstr_t)Holder);
theApp.m_pRs->MoveNext();i++;
m_strNum.Format("%d",iCount);
m_listDisp.SetRedraw(TRUE);}
voidCViewDlg::OnButtonOk(){
OnOK();
//TODO:Addyourcontrolnotificationhandlercodehere}case2:
ViewProvider();break;
case3:
ViewInlib();break;
case4:
ViewOutlib();break;
case5:}
UpdateData(false);
//TODO:Addextrainitializationhere
returnTRUE;//returnTRUEunlessyousetthefocustoacontrol//EXCEPTION:OCXPropertyPagesshouldreturnFALSE
ViewLog();break;
voidCViewDlg::ViewLog(){
m_listDisp.DeleteAllItems();m_listDisp.SetRedraw(FALSE);
_variant_tHolder,strQuery;
strQuery="select*fromlog";
theApp.ADOExecute(theApp.m_pRs,strQuery);
intiCount=theApp.m_pRs->GetRecordCount();}
m_listDisp.SetRedraw(TRUE);
if(0==iCount)
return;
theApp.m_pRs->MoveFirst();inti=0;
while(!theApp.m_pRs->adoEOF){}
m_strNum.Format("%d",iCount);
Holder=theApp.m_pRs->GetCollect("Admin_name");if(Holder.vt!=VT_NULL)
m_listDisp.InsertItem(i,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("do_what");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,1,(char*)(_bstr_t)Holder);
Holder=theApp.m_pRs->GetCollect("do_date");if(Holder.vt!=VT_NULL)
m_listDisp.SetItemText(i,2,(char*)(_bstr_t)Holder);
theApp.m_pRs->MoveNext();i++;
友情提示:本文中關(guān)于《服裝倉儲貨品管理技巧》給出的范例僅供您參考拓展思維使用,服裝倉儲貨品管理技巧:該篇文章建議您自主創(chuàng)作。
來源:網(wǎng)絡(luò)整理 免責聲明:本文僅限學習分享,如產(chǎn)生版權(quán)問題,請聯(lián)系我們及時刪除。