版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
...wd......wd......wd...圖書管理系統(tǒng)的設(shè)計(jì)在圖書管理系統(tǒng)用計(jì)算機(jī)管理圖書是一種計(jì)算機(jī)應(yīng)用技術(shù)的創(chuàng)新,在計(jì)算機(jī)還未普及之前圖書管理都是由圖書管理人員手工記帳的方式來操作的.現(xiàn)在一般的圖書館都是采用計(jì)算機(jī)作為工具的實(shí)用的計(jì)算機(jī)圖書管理程序來幫助圖書館管理員進(jìn)展更有效的圖書管理。圖書管理系統(tǒng)是典型的信息管理系統(tǒng)(MIS),其開發(fā)主要包括后臺(tái)數(shù)據(jù)庫的建設(shè)和維護(hù)以及前端應(yīng)用程序的開發(fā)兩個(gè)方面。對(duì)于前者要求建設(shè)起數(shù)據(jù)一致性和完整性強(qiáng)、數(shù)據(jù)安全性好的庫。而對(duì)于后者則要求應(yīng)用程序功能完備,易使用等特點(diǎn)。關(guān)鍵字:圖書,面向?qū)ο?,軟件工程目錄第一章概?11.1開發(fā)背景 11.2管理信息系統(tǒng)產(chǎn)生的背景 11.3系統(tǒng)功能要求的分析 2第二章開發(fā)環(huán)境及實(shí)現(xiàn)技術(shù)介紹 32.1開發(fā)環(huán)境 32.2開發(fā)工具簡介 3第三章圖書管理系統(tǒng)的設(shè)計(jì)和實(shí)現(xiàn) 53.1系統(tǒng)的設(shè)計(jì) 53.1.1概要設(shè)計(jì) 53.1.2詳細(xì)設(shè)計(jì) 73.2系統(tǒng)的實(shí)現(xiàn) 93.2.1主界面的設(shè)計(jì)與實(shí)現(xiàn) 123.2.2圖書管理模塊的設(shè)計(jì)與實(shí)現(xiàn) 153.2.3讀者管理模塊的設(shè)計(jì)與實(shí)現(xiàn) 193.2.4圖書借閱管理模塊的實(shí)現(xiàn) 223.2.5系統(tǒng)管理模塊的設(shè)計(jì)與實(shí)現(xiàn) 25第四章圖書管理系統(tǒng)的運(yùn)行說明 404.1運(yùn)行環(huán)境 40第一章概述1.1開發(fā)背景在圖書管理系統(tǒng)用計(jì)算機(jī)管理圖書是一種計(jì)算機(jī)應(yīng)用技術(shù)的創(chuàng)新,在計(jì)算機(jī)還未普及之前圖書管理都是由圖書管理人員手工記帳的方式來操作的.現(xiàn)在一般的圖書館都是采用計(jì)算機(jī)作為工具的實(shí)用的計(jì)算機(jī)圖書管理程序來幫助圖書館管理員進(jìn)展更有效的圖書管理。1.2圖書管理系統(tǒng)產(chǎn)生的背景圖書管理系統(tǒng)是典型的信息管理系統(tǒng)(MIS),其開發(fā)主要包括后臺(tái)數(shù)據(jù)庫的建設(shè)和維護(hù)以及前端應(yīng)用程序的開發(fā)兩個(gè)方面。對(duì)于前者要求建設(shè)起數(shù)據(jù)一致性和完整性強(qiáng)、數(shù)據(jù)安全性好的庫。而對(duì)于后者則要求應(yīng)用程序功能完備,易使用等特點(diǎn)。
經(jīng)過分析,我們使用MICROSOFT公司的VISUALBASIC開發(fā)工具,利用其提供的各種面向?qū)ο蟮拈_發(fā)工具,尤其是數(shù)據(jù)窗口這一能方便而簡潔操縱數(shù)據(jù)庫的智能化對(duì)象,首先在短時(shí)間內(nèi)建設(shè)系統(tǒng)應(yīng)用原型,然后,對(duì)初始原型系統(tǒng)進(jìn)展需求迭代,不斷修正和改良,直到形成用戶滿意的可行系統(tǒng)。1.3系統(tǒng)功能要求的分析圖書管理系統(tǒng)主要服務(wù)與圖書管理人員,包含的功能模塊主要有:圖書管理:圖書類別管理,圖書信息管理讀者管理:讀者管理,讀者信息管理.圖書借閱管理:借書管理,還書管理.系統(tǒng)管理:添加管理員,修改密碼,退出系統(tǒng)第二章開發(fā)環(huán)境及實(shí)現(xiàn)技術(shù)介紹2.1開發(fā)環(huán)境硬件平臺(tái)CPUIntelP41.5G主板Intel850芯片組的GA-8TX-C內(nèi)存2×128M的三星Rambus內(nèi)存硬盤SeagateBarracuda7200.780G顯卡Unika小妖G9800顯示器美格770PF,17寸純平顯示器軟件環(huán)境操作系統(tǒng)MicrosoftWindowsXP簡體中文專業(yè)版+SP1辦公軟件MicrosoftOffice2003顯卡驅(qū)動(dòng)nVIDIAForceWare驅(qū)動(dòng)56.72版ForWin2000/XP2.2開發(fā)軟件介紹本系統(tǒng)所采用的編程語言為visualbasic6.0與微軟的access作為操作數(shù)據(jù)庫.現(xiàn)分別對(duì)其簡單介紹:VisualBasic6.0是Micrsoft公司出品的開發(fā)工具,VisualBasic是一種可視化的,面向?qū)ο蟮腤indows開發(fā)語言,它具有易用,通用和開發(fā)效率高的特點(diǎn)。隨著微軟對(duì)它不斷地改良以及計(jì)算機(jī)本身性能的提高,使得VisualBasic越來越適合一般的應(yīng)用程序開發(fā)。正如BillGate所說,世界上絕大多數(shù)的Windows應(yīng)用程序是用VisualBasic編寫的。在眾多的開發(fā)工具中,我們?yōu)槭裁匆x擇VisualBasic6.0呢因?yàn)閂B具有眾多其它開發(fā)工具所沒有的優(yōu)點(diǎn)!具體介紹如下:開發(fā)的高效語言的高效編譯的高效執(zhí)行的高效維護(hù)的高效基于以上理由,我們毫不憂郁的選擇了VB6.0做為我們的開發(fā)工具??!主要的控件及其基本屬性,事件簡介命令按鈕類的控件:Caption屬性:用來顯示在控件上的標(biāo)題。Enable屬性:控制控件的激活狀態(tài)灰色或可用。Appearance屬性:值為1時(shí),則以3D效果顯示該控件,0則不然。Backcolor屬性:用來改變?cè)诎粹o上顯示圖像的背風(fēng)光。Cancel屬性:該屬性決定按鈕是否為一個(gè)〞取消〞按鈕。Default屬性:決定哪一個(gè)命令按鈕控件是窗體的缺省命令按鈕.Font屬性:控制各種文字字體類型.Left,top,height,width屬性:設(shè)定控件的位置與大小.Style,picture屬性:決定按鈕的顯示方式是否為圖像形式出現(xiàn).Visible屬性:確定控件運(yùn)行時(shí)是否為可見.Index屬性:當(dāng)控件為一控件數(shù)組時(shí),此屬性值為該控件在數(shù)組的下標(biāo)值.DownPicture屬性:設(shè)置/返回一個(gè)對(duì)圖片的引用,該圖片在按鈕被單擊處于壓下狀態(tài)時(shí)顯示。DisabledPicture屬性:設(shè)置/返回一個(gè)對(duì)圖片的引用,該圖片在控件無效時(shí)顯示在控件中。MaskColor屬性:設(shè)置/返回一個(gè)在按鈕的圖片中作為“掩碼“的的顏色Picture屬性:設(shè)置返回commandButton控件中要顯示的圖片。命令按鈕類的事件:單擊事件――Click事件觸發(fā)與適用此事件是在一個(gè)命令按鈕對(duì)象上按下然后釋放一個(gè)鼠標(biāo)按鈕時(shí)發(fā)生。命令按鈕的Click事件僅對(duì)當(dāng)單擊鼠標(biāo)時(shí)發(fā)生。事件處理過程按鈕單擊事件的處理過程為:PrivateSubobject-Click〔IndexAsInteger〕其中Object為引發(fā)該事件的對(duì)象名稱。如果是命令按鈕的控件是數(shù)組,則需要使用Index參數(shù)標(biāo)識(shí)該控件。獲得焦點(diǎn)――GotFocus事件觸發(fā)與適用當(dāng)命令按鈕獲得焦點(diǎn)產(chǎn)生該事件,獲得焦點(diǎn)可以通過諸如Tab切換或單擊對(duì)象之類的用戶動(dòng)作,或在代碼中用SetFocus方法改變焦點(diǎn)來實(shí)現(xiàn)。事件處理過程命令按鈕GotFoucs事件處理過程為:PrivateSubObject-GotFocus〔IndexAsInteger〕LostFocus事件:當(dāng)一個(gè)對(duì)象失去焦點(diǎn)時(shí)發(fā)生KeyDown事件:當(dāng)命令按鈕具有焦點(diǎn)時(shí)按下一個(gè)鍵時(shí)發(fā)生KeyUp事件:當(dāng)命令按鈕具有焦點(diǎn)時(shí)釋放一個(gè)鍵時(shí)發(fā)生。KeyPress事件:當(dāng)用戶按下或松開一個(gè)ANSI鍵時(shí)發(fā)生。MouseDown事件:當(dāng)在命令按鈕上按下鼠標(biāo)按鈕時(shí)發(fā)生。MouseMove事件:當(dāng)命令按鈕上移動(dòng)鼠標(biāo)時(shí)發(fā)生。MouseUp事件:當(dāng)在命令按鈕上釋放鼠標(biāo)按鈕時(shí)發(fā)生。標(biāo)簽框類的控件類的控件:Caption屬性:在應(yīng)用程序界面上參加說明。Autosize屬性:決定控件是否自動(dòng)改變大小以顯示其全部內(nèi)容。Backstyle屬性:用以指示標(biāo)簽是否透明.Bordstyle屬性:用以設(shè)定控件是否有邊框。文本框類的控件:Text屬性:通過像text屬性賦值的方法來改變?cè)搶傩缘闹?。Maxlength屬性:該屬性設(shè)定在文本框控件中能夠輸入的最大字符數(shù)。Multline屬性:該屬性設(shè)定text字符串中是否承受換行符。Scrollbars屬性:該屬性決定是否為文本框加滾動(dòng)條。Passwordchar屬性:該屬性設(shè)定輸入文本的特殊顯示字符,在設(shè)計(jì)密碼程序時(shí)非常有用。Change事件屬性:文本框的內(nèi)容發(fā)生改變時(shí),相應(yīng)的控件之間發(fā)生相應(yīng)的改變,具有即時(shí)性。Keypress:事件由用戶在文本框控件中按任意鍵觸發(fā)。Alignment屬性:設(shè)定控件中的文本對(duì)其方式Appearance屬性:設(shè)定一個(gè)對(duì)象在運(yùn)行時(shí)是否可以3D效果顯示。BackColor屬性:設(shè)置返回背風(fēng)光BorderStyle屬性:設(shè)置對(duì)象的邊框樣式DataField屬性:設(shè)定數(shù)據(jù)使用者將被綁定到的字段名DataFormat屬性:設(shè)定DataFormat對(duì)象,用于數(shù)據(jù)綁定DataMember屬性:從數(shù)據(jù)供給程序提供的幾個(gè)數(shù)據(jù)成員中返回/設(shè)定一個(gè)特定的數(shù)據(jù)成員DataSource屬性:設(shè)定控件綁定的一個(gè)數(shù)據(jù)源DragIcon屬性:設(shè)定圖標(biāo),它將在拖放操作中作為指針顯示DragMode模式:設(shè)定一個(gè)值,確定在拖放操作中所用方式Enabled屬性:設(shè)置/返回運(yùn)行時(shí)TextBox是否相應(yīng)用戶事件Font屬性:設(shè)置/返回字體屬性ForeColor屬性:設(shè)置/返回文本的前風(fēng)光Height屬性:設(shè)置/返回TextBox的高度IMEMode屬性:設(shè)置/返回?cái)?shù)值用來確定輸入方法編輯器的狀態(tài)Index屬性:設(shè)置/返回唯一的標(biāo)識(shí)控件數(shù)組中該控件的編號(hào)Left屬性:設(shè)置/返回TextBox控件的水平位置Locked屬性:設(shè)置/返回TextBox中文本是否可編輯LinkItem屬性:設(shè)置/返回DDE與另一個(gè)應(yīng)用程序會(huì)話時(shí),傳給承受端的數(shù)據(jù)MaxLength屬性:設(shè)置/返回一個(gè)值,指定在TextBox控件中能夠輸入的字符最大值MouseIcon屬性:設(shè)置/返回自定義鼠標(biāo)的圖標(biāo)Top屬性:設(shè)置/返回TextBox控件的垂直位置Tag屬性:存儲(chǔ)過程所需的附加數(shù)據(jù)文本框類的事件:Change事件:當(dāng)改變文本框內(nèi)容時(shí)發(fā)生Click事件:鼠標(biāo)單擊控件時(shí)發(fā)生DblClick事件:用鼠標(biāo)左鍵雙擊控件時(shí)發(fā)生DragDrop事件:在一個(gè)完整的拖放動(dòng)作完成或使用Drag方法,并將其Action參數(shù)設(shè)置為2時(shí)發(fā)生DragOver事件:在拖放操作正在進(jìn)展時(shí)發(fā)生GotFocus事件:當(dāng)一個(gè)命令按鈕獲得焦點(diǎn)時(shí)發(fā)生LinkClose事件:當(dāng)一個(gè)DDE對(duì)話完畢時(shí)發(fā)生LinkError事件:當(dāng)一個(gè)DDE對(duì)話框過程中出現(xiàn)錯(cuò)誤時(shí),該事件發(fā)生KeyDown事件:當(dāng)命令按鈕具有焦點(diǎn)時(shí)按下一個(gè)鍵時(shí)發(fā)生Validate事件:在焦點(diǎn)轉(zhuǎn)換到另一個(gè)控件之前發(fā)生,此時(shí)該控件的CausesValidation屬性值設(shè)置為True單項(xiàng)選擇按鈕類的控件:Caption屬性:顯示在控件上的文本,是單項(xiàng)選擇按鈕的標(biāo)題。Alignment屬性:決定單項(xiàng)選擇按鈕的標(biāo)題在控件上的位置。Enable屬性:該控件為灰色時(shí)為false,表示運(yùn)行時(shí)不可用。Index屬性:屬性值表示為單項(xiàng)選擇按鈕組成的控件中某個(gè)按鈕的索引值。Tabindex屬性:建設(shè)控件時(shí),vb自動(dòng)為其分配一個(gè)tabindex值,利用tab鍵可以在控件之間切換焦點(diǎn)。Value屬性:反映控件狀態(tài)的屬性,返回true表示已選擇了該按鈕。Appearance屬性:設(shè)置/返回一個(gè)對(duì)象在運(yùn)行時(shí)是否以3D效果顯示。BackColor屬性:設(shè)置/返回背風(fēng)光。Container屬性:設(shè)置/返回Form上的控件屬性。DataField屬性:設(shè)置/返回?cái)?shù)據(jù)使用者將被綁定到的字段名。DataFormat屬性:設(shè)置/返回DataFormat對(duì)象,一個(gè)綁定對(duì)象將附加到它。DisabledPicture屬性:設(shè)置/返回一個(gè)對(duì)圖像的引用,該圖片在控件無效時(shí)顯示在控件中。DownPicture屬性:設(shè)置/返回一個(gè)對(duì)圖片的引用,該圖片在控件單擊下處于壓下狀態(tài)時(shí)顯示。DragMode屬性:設(shè)置/返回一個(gè)值,確定在拖放操作中所用的方式。Font屬性:設(shè)置/返回字體屬性。FontBold屬性:設(shè)置/返回字體粗體樣式。FontItalic屬性:設(shè)置/返回字體斜體樣式。FontStrikethru屬性:設(shè)置/返回字體刪除線樣式。FontUnderLine屬性:設(shè)置/返回字體下劃線樣式。FontName屬性:設(shè)置/返回控件中顯示文本所用的字體大小。FontSize屬性:設(shè)置/返回控件中顯示文本所用的字體大小Height屬性:設(shè)置/返回控件的高度。MaskColor屬性:設(shè)置/返回一個(gè)在控件的圖片中作為掩碼的顏色。MousePointer屬性:設(shè)置/返回一個(gè)值,該值指示在運(yùn)行時(shí)當(dāng)鼠標(biāo)移動(dòng)到對(duì)象上時(shí)顯示的指針類型。單項(xiàng)選擇按鈕類的常用事件:Click事件:鼠標(biāo)單擊控件時(shí)發(fā)生。DbClick事件:當(dāng)在一個(gè)對(duì)象上按下和釋放鼠標(biāo)按鈕并再次按下和釋放按鈕時(shí),該事件發(fā)生。DragDrop事件:在一個(gè)完整的拖放動(dòng)作或使用Drag方法,并將其Action參數(shù)設(shè)置位2時(shí),該事件發(fā)生。DragOver事件:在拖放操作正在進(jìn)展時(shí)發(fā)生。GotFocus事件:當(dāng)獲的對(duì)象焦點(diǎn)時(shí)發(fā)生。LostFocus事件:當(dāng)對(duì)象失去焦點(diǎn)時(shí)發(fā)生。KeyDown事件:當(dāng)控件具有焦點(diǎn)時(shí)按下一個(gè)鍵時(shí)發(fā)生。KeyUp事件:當(dāng)控件具有焦點(diǎn)時(shí)釋放一個(gè)鍵時(shí)發(fā)生。KeyPress事件:當(dāng)用戶按下或釋放ANSI一個(gè)鍵時(shí)發(fā)生。MouseDown事件:當(dāng)在控件上按下鼠標(biāo)鍵時(shí)發(fā)生。MouseMove事件:在控件上移動(dòng)鼠標(biāo)時(shí)發(fā)生。MouseUp事件:在控件上釋放鼠標(biāo)時(shí)發(fā)生。復(fù)選按鈕類的控件:Caption屬性:缺省為check1…。Index屬性:該屬性值為復(fù)選框控件數(shù)組的下標(biāo).Value屬性:value為0表空白,為1表勾號(hào),為2表示灰色勾號(hào).Container屬性:Form控件上的容器。DataChangeed屬性:設(shè)置/返回一個(gè)值,指出被綁定的控件中的數(shù)據(jù)已經(jīng)被某進(jìn)程修改。DataField屬性:設(shè)置或返回?cái)?shù)據(jù)使用者將被綁定到的字段名。DataFormat屬性:設(shè)置或返回DataFormat對(duì)象,用于數(shù)據(jù)綁定。Datasource屬性:設(shè)置或返回控件綁定的一個(gè)數(shù)據(jù)源。DisabledPicture屬性:設(shè)置或返回一個(gè)對(duì)圖片的引用,該圖片在控件無效時(shí)顯示在控件中。DownPicture屬性:設(shè)置或返回一個(gè)對(duì)圖片的引用,該圖片在控件被單擊處于壓下狀態(tài)時(shí)顯示。DragIcon屬性:設(shè)置或返回圖標(biāo),它將在拖放操作中做為指針顯示。DragMode屬性:設(shè)置返回一個(gè)值,確定在拖放操作中所用方式。Font屬性:設(shè)置或返回字體的屬性。Name屬性:設(shè)置或返回控件的標(biāo)識(shí)名。Value屬性:設(shè)置或返回控件的狀態(tài)。復(fù)選按鈕類的控件的基本領(lǐng)件:Click事件:鼠標(biāo)單擊控件時(shí)發(fā)生。DragDrop事件:在一個(gè)完整的拖放動(dòng)作完成或使用Drag方法,并將其Action參數(shù)設(shè)置為2時(shí)發(fā)生。DragOver事件:在拖放操作正在進(jìn)展時(shí)發(fā)生。GotFocus事件:在對(duì)象獲的焦點(diǎn)時(shí)發(fā)生。,OLECompleteDrag事件:當(dāng)源部件被放到目標(biāo)時(shí)發(fā)生,并通知源部件拖放操作被執(zhí)行或取消。OLEDragDrag事件:當(dāng)源部件決定放操作能發(fā)生,卻源部件被放到目標(biāo)部件時(shí),此事件發(fā)生??蚣茴惖目丶?)List屬性:列表框控件的表項(xiàng)是使用數(shù)組的方式保存,數(shù)組的每一個(gè)元素存儲(chǔ)列表控件的一個(gè)表項(xiàng)Listcount屬性:控件列表局部工程的個(gè)數(shù)。Mutselect屬性:可以設(shè)置列表框?yàn)閱雾?xiàng)選擇或允許多項(xiàng)選擇屬性.Selectd屬性:標(biāo)示一個(gè)數(shù)組,數(shù)組各元素為:Selected(0),selected(1)…滾動(dòng)條類的控件:Value屬性:滾動(dòng)條上滑塊所在位置由value值所決定。Max和min屬性:對(duì)value值的最大,最小進(jìn)展限制。Largechange屬性:用戶點(diǎn)擊滾動(dòng)條與鍵頭之間的區(qū)域時(shí),value的改變量。4)OnClick事件:用來添加按鈕的單擊事件所執(zhí)行的程序代碼。定時(shí)器類類的控件:Interval屬性:表示定時(shí)的時(shí)間間隔,以毫秒為單位。Enable屬性:為true時(shí)(缺省值),激活定時(shí)器開場計(jì)時(shí);為false時(shí)處于休眠狀態(tài).數(shù)據(jù)庫連接方式選擇Visualbasic6.0連接數(shù)據(jù)庫的主要方式以下幾種方式:一是:用data控件進(jìn)展數(shù)據(jù)庫鏈接,二是利用adodc〔ADODataControl)進(jìn)展數(shù)據(jù)庫鏈接。三是:利用DataEnvironment進(jìn)展數(shù)據(jù)庫鏈接.四是利用ADO(ActiveXDataObjects)進(jìn)展編程:現(xiàn)在我們來大致對(duì)這幾種技術(shù)應(yīng)用介紹:用data控件進(jìn)展數(shù)據(jù)庫鏈接.第一步:給窗體添加一個(gè)Data控件。第二步:用Access建設(shè)一個(gè)名為Pad的數(shù)據(jù)庫,在庫中建設(shè)一個(gè)表Myset,給表添加四個(gè)字段:backcolor〔數(shù)據(jù)〕,forecolor(文本〕,fontname(文本〕,fontsize〔文本〕。注意:請(qǐng)將庫文件存入程序所在目錄。如果你的機(jī)器沒安裝有Access,可通過VB建庫。利用adodc〔ADODataControl)進(jìn)展數(shù)據(jù)庫鏈接:使用adodata控件訪問數(shù)據(jù)庫可以完全不用編寫代碼,只需要通過簡單的設(shè)置和操作其屬性就可以實(shí)現(xiàn)與數(shù)據(jù)庫的連接,通過綁定數(shù)據(jù)感知控件,就能提供一個(gè)訪問數(shù)據(jù)庫的界面,用來實(shí)現(xiàn)對(duì)數(shù)據(jù)庫的瀏覽,貼加,刪除,修改等操作.利用DAO對(duì)數(shù)據(jù)庫進(jìn)展操縱:在visualbasic中提供了兩種與jet數(shù)據(jù)引擎接口的方法:data控件與數(shù)據(jù)訪問對(duì)象(DAO)DAO是databaseobject的英文縮寫,要訪問數(shù)據(jù)庫一方面數(shù)據(jù)庫要提供訪問接口,另一方面要在編程環(huán)境中有對(duì)數(shù)據(jù)庫的支持.DAO模型是設(shè)計(jì)關(guān)系數(shù)據(jù)庫系統(tǒng)構(gòu)造的對(duì)象類的集合.他們提供了管理關(guān)系型數(shù)據(jù)庫系統(tǒng)所需要的全部操作屬性和方法,這其中包括建設(shè)數(shù)據(jù)庫,定義表,字段和建設(shè)表間關(guān)系,定位和查詢數(shù)據(jù)庫等.關(guān)系數(shù)據(jù)庫介紹:關(guān)系數(shù)據(jù)庫是目前各類數(shù)據(jù)庫中最重要、最流行的數(shù)據(jù)庫,他應(yīng)用數(shù)學(xué)方法來處理數(shù)據(jù)庫數(shù)據(jù),是目前使用最廣泛的數(shù)據(jù)庫系統(tǒng)。20世紀(jì)70年代以后開發(fā)的數(shù)據(jù)庫管理系統(tǒng)產(chǎn)品幾乎都是基于關(guān)系的。在數(shù)據(jù)庫開展的歷史上,最重要的成就就是關(guān)系模型。關(guān)系數(shù)據(jù)庫系統(tǒng)與非關(guān)系數(shù)據(jù)庫系統(tǒng)的區(qū)別是:關(guān)系系統(tǒng)只有“表“這一種數(shù)據(jù)構(gòu)造;而非關(guān)系數(shù)據(jù)庫系統(tǒng)還有其他數(shù)據(jù)構(gòu)造,對(duì)這些數(shù)據(jù)構(gòu)造有其他的操作。構(gòu)造化查詢語言SQL〔StructuredQueryLanguage〕是一種介于關(guān)系代數(shù)與關(guān)系演算之間的語言,其功能包括查詢、操縱、定義和控制四個(gè)方面,是一個(gè)通用的、功能極強(qiáng)的關(guān)系數(shù)據(jù)庫語言。目前已成為關(guān)系數(shù)據(jù)庫的標(biāo)準(zhǔn)語言Microsoft
Access介紹:使用
Microsoft
Access,可以在單一的數(shù)據(jù)庫文件中管理所有的信息。在這個(gè)文件中,用戶可以將自己的數(shù)據(jù)分別保存在各自獨(dú)立的存儲(chǔ)空間中,這些空間稱作表;可以使用聯(lián)機(jī)窗體來查看、添加及更新表中的數(shù)據(jù);使用查詢來查找并檢索所要的數(shù)據(jù);也可以使用報(bào)表以特定的版面布置來分析及打印數(shù)據(jù)。
如果要保存數(shù)據(jù),請(qǐng)為每一種類型的信息創(chuàng)立一個(gè)表。如果要從查詢、窗體或報(bào)表中的多個(gè)表中將數(shù)據(jù)合并在一起,就要定義各個(gè)表之間的關(guān)系。
如果要搜索并檢索符合指定條件的數(shù)據(jù),包括來自多個(gè)表中的數(shù)據(jù),就要?jiǎng)?chuàng)立查詢。查詢的同時(shí)也可以更新或刪除多條記錄,并對(duì)數(shù)據(jù)執(zhí)行內(nèi)嵌或自定義的計(jì)算。
如果要簡單地直接在某個(gè)表中查看、輸入及更改數(shù)據(jù),請(qǐng)創(chuàng)立一個(gè)窗體。在翻開一個(gè)窗體時(shí),Microsoft
Access
將從一個(gè)或多個(gè)表中檢索數(shù)據(jù),并使用用戶在“窗體向?qū)Ж曔x擇的版面布局或所創(chuàng)立的版面布局,將窗體顯示在屏幕上。
如果要分析數(shù)據(jù)或?qū)?shù)據(jù)以特定的方式打印出來,請(qǐng)創(chuàng)立一個(gè)報(bào)表。例如,可以打印一份將數(shù)據(jù)分組并計(jì)算數(shù)據(jù)總和的報(bào)表,也可以打印另一份帶有各種數(shù)據(jù)格式的打印郵件標(biāo)簽的報(bào)表。第三章圖書管理系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)3.1系統(tǒng)的設(shè)計(jì)3.1.1系統(tǒng)的概要設(shè)計(jì)該系統(tǒng)考慮將整個(gè)系統(tǒng)分解成如下模塊:主界面主界面圖書管理圖書信息管理讀者類別管理讀者信息管理圖書借閱管理借書管理還書管理系統(tǒng)管理登錄圖書類別管理讀者管理3.1.2系統(tǒng)的詳細(xì)設(shè)計(jì)1.讀者類別表2.讀者信息表:3.借閱信息表:4.書籍信息表:5.圖書類別表:6.系統(tǒng)管理表:3.2系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)3.2.1系統(tǒng)的主界面的設(shè)計(jì)與實(shí)現(xiàn)主界面代碼:PrivateSubadd_admin_Click()frmadduser.ShowEndSubPrivateSubadd_back_book_Click()frmbackbookinfo.ShowEndSubPrivateSubadd_book_info_Click()frmaddbookinfo.ShowEndSubPrivateSubadd_book_style_Click()frmaddbookstyle.ShowEndSubPrivateSubadd_lend_book_Click()frmfindbook.ShowEndSubPrivateSubadd_reader_info_Click()frmaddreaderinfo.ShowEndSubPrivateSubadd_reader_style_Click()frmaddreaderstyle.ShowEndSubPrivateSubchange_pwd_Click()frmchangepwd.ShowEndSubPrivateSubdel_book_info_Click()frmmodifybookinfo.ShowEndSubPrivateSubdel_book_style_Click()frmmodifybookstyle.ShowEndSubPrivateSubdel_reader_info_Click()frmreaderinfo.ShowEndSubPrivateSubdel_reader_style_Click()frmmodifyreaderstyle.ShowEndSubPrivateSubexit_sys_Click()EndEndSubPrivateSubfind_book_info_Click()frmfindbook.ShowEndSubPrivateSubfind_lend_book_Click()frmfindborrowinfo.ShowEndSubPrivateSubfind_reader_info_Click()frmfindreader.ShowEndSubPrivateSubmodify_book_info_Click()frmmodifybookinfo.ShowEndSubPrivateSubmodify_book_style_Click()frmmodifybookstyle.ShowEndSubPrivateSubmodify_reader_info_Click()frmreaderinfo.ShowEndSubPrivateSubmodify_reader_style_Click()frmmodifyreaderstyle.ShowEndSub3.2.2圖書管理模塊的設(shè)計(jì)與實(shí)現(xiàn)圖書管理模塊主要由:圖書類別管理,圖書信息管理.圖書類別管理又分別由以下幾個(gè)界面構(gòu)成:添加圖書類別添加圖書類別代碼:PrivateSubCommand1_Click()Dimrs_bookstyleAsNewADODB.RecordsetDimsqlAsStringIfTrim(Text1.Text)=""ThenMsgBox"圖書種類不能為空",vbOKOnly+vbExclamation,""Text1.SetFocusExitSubEndIfIfTrim(Text2.Text)=""ThenMsgBox"種類編號(hào)不能為空",vbOKOnly+vbExclamation,""Text2.SetFocusExitSubEndIfsql="select*from圖書類別where類別名稱='"&Text1.Text&"'"rs_bookstyle.Opensql,conn,adOpenKeyset,adLockPessimisticIfrs_bookstyle.EOFThenrs_bookstyle.AddNewrs_bookstyle.Fields(0)=Trim(Text1.Text)rs_bookstyle.Fields(1)=Trim(Text2.Text)rs_bookstyle.UpdateMsgBox"添加圖書類別成功!",vbOKOnly,""rs_bookstyle.CloseElseMsgBox"讀者類別重復(fù)!",vbOKOnly+vbExclamation,""Text1.SetFocusText1.Text=""rs_bookstyle.CloseExitSubEndIfEndSub修改圖書類別:修改圖書類別代碼:PrivateSubForm_Load()DimsqlAsStringOnErrorGoToloaderrorsql="select*from圖書類別"rs_reader.CursorLocation=adUseClientrs_reader.Opensql,conn,adOpenKeyset,adLockPessimistic'翻開數(shù)據(jù)庫cmdupdate.Enabled=False'設(shè)定datagrid控件屬性DataGrid1.AllowAddNew=False'不可增加DataGrid1.AllowDelete=False'不可刪除DataGrid1.AllowUpdate=FalseIfuserpow="guest"Then'權(quán)限相關(guān)Frame2.Enabled=FalseEndIfSetDataGrid1.DataSource=rs_readerExitSubloaderror:MsgBoxErr.DescriptionEndSub3.2.3讀者管理模塊的設(shè)計(jì)與實(shí)現(xiàn)1.添加讀者類別界面:PrivateSubCommand1_Click()DimsqlAsStringIfTrim(Text1.Text)=""ThenMsgBox"讀者種類不能為空",vbOKOnly+vbExclamation,""Text1.SetFocusExitSubEndIfIfTrim(Text2.Text)=""ThenMsgBox"借書數(shù)量不能為空",vbOKOnly+vbExclamation,""Text2.SetFocusExitSubEndIfIfTrim(Text3.Text)=""ThenMsgBox"借書期限不能為空",vbOKOnly+vbExclamation,""Text3.SetFocusExitSubEndIfIfTrim(Text4.Text)=""ThenMsgBox"有限期限不能為空",vbOKOnly+vbExclamation,""Text4.SetFocusExitSubEndIfsql="select*from讀者類別where種類名稱='"&Text1.Text&"'"rs_readerstyle.Opensql,conn,adOpenKeyset,adLockPessimisticIfrs_readerstyle.EOFThenrs_readerstyle.AddNewrs_readerstyle.Fields(0)=Trim(Text1.Text)rs_readerstyle.Fields(1)=CInt(Text2.Text)rs_readerstyle.Fields(2)=CInt(Text3.Text)rs_readerstyle.Fields(3)=CInt(Text4.Text)rs_readerstyle.UpdateMsgBox"添加讀者類別成功!",vbOKOnly,""rs_readerstyle.CloseElseMsgBox"讀者類別重復(fù)!",vbOKOnly+vbExclamation,""Text1.SetFocusText1.Text=""rs_readerstyle.CloseExitSubEndIfEndSub查詢讀者信息代碼分析:PrivateSubCommand1_Click()Dimrs_findreaderAsNewADODB.RecordsetDimsqlAsStringIfCheck1.Value=vbCheckedThensql="讀者編號(hào)='"&Trim(Text1.Text&"")&"'"EndIfIfCheck2.Value=vbCheckedThenIfTrim(sql)=""Thensql="讀者姓名='"&Trim(Text2.Text&"")&"'"Elsesql=sql&"and讀者姓名='"&Trim(Text2.Text&"")&"'"EndIfEndIfIfCheck3.Value=vbCheckedThenIfTrim(sql)=""Thensql="讀者類別='"&Trim(Combo1.Text&"")&"'"Elsesql=sql&"and讀者類別='"&Trim(Combo1.Text&"")&"'"EndIfEndIfsql="select*from讀者信息where"&sqlrs_findreader.CursorLocation=adUseClientrs_findreader.Opensql,conn,adOpenKeyset,adLockPessimisticDataGrid1.AllowAddNew=FalseDataGrid1.AllowDelete=FalseDataGrid1.AllowUpdate=FalseSetDataGrid1.DataSource=rs_findreader'rs_findreader.CloseEndSub圖書借閱管理模塊的設(shè)計(jì)與實(shí)現(xiàn)代碼實(shí)現(xiàn):PrivateSubCommand1_Click()DimsqlAsStringDimrs_findAsNewADODB.RecordsetIfOption1.Value=TrueThensql="select*from書籍信息where是否被借出='是'"EndIfIfOption2.Value=TrueThensql="select*from書籍信息where是否被借出='否'"EndIfIfOption3.Value=TrueThensql="select*from借閱信息where讀者姓名='"&Text1.Text&"'"EndIfrs_find.CursorLocation=adUseClientrs_find.Opensql,conn,adOpenKeyset,adLockPessimisticDataGrid1.AllowAddNew=FalseDataGrid1.AllowDelete=FalseDataGrid1.AllowUpdate=FalseSetDataGrid1.DataSource=rs_findEndSub3.2.5系統(tǒng)管理模塊的設(shè)計(jì)與實(shí)現(xiàn)PrivateSubCommand1_Cl
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度畜牧企業(yè)家畜養(yǎng)殖基地養(yǎng)殖技術(shù)支持與購銷合同3篇
- 二零二五年度江南大學(xué)高性能計(jì)算集群高性能網(wǎng)絡(luò)解決方案合同3篇
- 2024版店鋪合作經(jīng)營利潤分配合同版
- 2024涵洞施工勞務(wù)承包協(xié)議范本
- 二零二五年度城市綠地草皮養(yǎng)護(hù)與維護(hù)合作協(xié)議3篇
- 對(duì)沖基金在醫(yī)療健康產(chǎn)業(yè)投資中的角色和挑戰(zhàn)
- 2025版勞動(dòng)合同法規(guī)定下社保購買起始時(shí)間及雇主責(zé)任約定書3篇
- 小學(xué)生心理輔導(dǎo)與語言表達(dá)能力的提升
- 小學(xué)科學(xué)實(shí)驗(yàn)教學(xué)的藝術(shù)與技巧
- 專業(yè)化企業(yè)管理培訓(xùn):2024咨詢服務(wù)協(xié)議版B版
- 裝飾圖案智慧樹知到答案2024年齊魯工業(yè)大學(xué)
- 漢語言文學(xué)本科自考真題1301-全國-古代漢語
- 中醫(yī)藥健康管理服務(wù)流程
- 醫(yī)院開展反恐防恐知識(shí)培訓(xùn)
- MDCG 2020-3 Rev.1 歐盟更新醫(yī)療器械重大變更指南文件
- 五年級(jí)口算每頁100題(打印版)
- 人教版小學(xué)數(shù)學(xué)一年級(jí)上冊(cè)20以內(nèi)口算天天練試題全套
- 廣西欽州市浦北縣2023-2024學(xué)年七年級(jí)上學(xué)期期末語文試題
- 技術(shù)服務(wù)補(bǔ)充協(xié)議范本
- 內(nèi)河避碰條例題庫
- 四年級(jí)數(shù)學(xué)(四則混合運(yùn)算)計(jì)算題專項(xiàng)練習(xí)與答案
評(píng)論
0/150
提交評(píng)論