日本免费精品视频,男人的天堂在线免费视频,成人久久久精品乱码一区二区三区,高清成人爽a毛片免费网站

在線客服

圖書管理系統(tǒng)論文實(shí)用13篇

引論:我們?yōu)槟砹?3篇圖書管理系統(tǒng)論文范文,供您借鑒以豐富您的創(chuàng)作。它們是您寫作時(shí)的寶貴資源,期望它們能夠激發(fā)您的創(chuàng)作靈感,讓您的文章更具深度。

圖書管理系統(tǒng)論文

篇1

過(guò)去,大多數(shù)學(xué)校圖書館都是封閉式管理,通過(guò)卡片登記借閱信息,只能實(shí)現(xiàn)有限的流通,有的甚至不能正常對(duì)學(xué)生開(kāi)放,使得圖書館不能發(fā)揮應(yīng)有的作用;即使是實(shí)現(xiàn)了正常流通的,也不能提供領(lǐng)導(dǎo)管理上需要的各種信息如本館各種資料分布及借閱(流通)情況。

目前,我國(guó)學(xué)校圖書館辦館的要求及領(lǐng)先標(biāo)志就是藏書全部開(kāi)放,師生共享開(kāi)架借閱。這種借閱方式是當(dāng)前適合我國(guó)國(guó)情的發(fā)揮圖書館應(yīng)有作用的最佳方式,也是素質(zhì)教育的最好體現(xiàn)。它充分發(fā)揮了圖書館的功效,最大限度地為讀者服務(wù),這也是圖書館自動(dòng)化管理的最終目標(biāo)。實(shí)現(xiàn)這一目標(biāo),必須有現(xiàn)代化的管理手段和管理體制。為此,各地教育主管部門都逐步提出學(xué)校要采用圖書館管理系統(tǒng),從而實(shí)現(xiàn)人工管理達(dá)不到的一些功能并發(fā)揮圖書館的最大效益。而隨著越來(lái)越多的學(xué)校采用了現(xiàn)代化的管理軟件進(jìn)行管理,進(jìn)一步提升了學(xué)校管理的現(xiàn)代化水平,從而在競(jìng)爭(zhēng)中處于有利位置,也對(duì)其他兄弟學(xué)校起到了示范和促進(jìn)作用。自身發(fā)展的需要和上級(jí)部門的要求以及競(jìng)爭(zhēng)的需要決定了學(xué)校采用圖書館管理系統(tǒng)的必要性。

以計(jì)算機(jī)技術(shù)、存儲(chǔ)技術(shù)、通訊技術(shù)為主要內(nèi)容的現(xiàn)代信息技術(shù)的發(fā)展,使人類進(jìn)入了一個(gè)嶄新的信息時(shí)代。作為信息資源存儲(chǔ)、傳遞的專業(yè)機(jī)構(gòu),圖書館如何在新的技術(shù)條件下,適應(yīng)形勢(shì)發(fā)展,發(fā)揮自身優(yōu)勢(shì),開(kāi)拓信息渠道,更好地為用戶服務(wù),是一個(gè)新課題。也必將對(duì)現(xiàn)有的圖書館產(chǎn)生全面而深遠(yuǎn)的影響。因此,正確認(rèn)識(shí)信息時(shí)代對(duì)圖書管理工作的要求,使圖書館工作變得更加便利和高效,使資源共享更容易實(shí)現(xiàn),為讀者提供更加優(yōu)質(zhì)的服務(wù)十分重要。

在信息時(shí)代,各種冠以“數(shù)字圖書館”之類說(shuō)法的圖書館現(xiàn)代化論斷到處可見(jiàn)。那么什么是圖書館的現(xiàn)代化呢?判斷一個(gè)圖書館的現(xiàn)代化程度,應(yīng)該從圖書館最本質(zhì)的特性判斷。圖書館具有信息資源的收集保存、加工整理并使之有序化及傳遞信息資源的功能。這一點(diǎn)是書店和網(wǎng)站都無(wú)法做到的,也是圖書館最本質(zhì)的特性,是圖書館賴以生存的基礎(chǔ)。判斷圖書館的現(xiàn)代化程度,也應(yīng)該從這個(gè)最本質(zhì)的特性來(lái)判斷。

二、成熟的圖書管理系統(tǒng)決定因素

任何一套圖書館管理系統(tǒng)至少必須具備這樣一些功能:對(duì)圖書進(jìn)行編目也就是采集信息并上架、圖書檢索(查找)、圖書流通(借還)。然而僅僅有這些功能是不能稱為真正的現(xiàn)代化的管理型圖書館管理系統(tǒng)的。筆者認(rèn)為,一套系統(tǒng)是否成熟還決定于以下幾個(gè)方面:

1、符合相關(guān)的標(biāo)準(zhǔn)

例如教育部最新頒布的《教育管理信息化標(biāo)準(zhǔn)》規(guī)范、我國(guó)圖書館界通用的CNMARC格式標(biāo)準(zhǔn)、目前通用的《中圖法四》等。

《教育管理信息化標(biāo)準(zhǔn)》的頒布將為教育部門對(duì)教育數(shù)據(jù)進(jìn)行總體的規(guī)劃和組織,建立起統(tǒng)一的數(shù)據(jù)平臺(tái)提供有力的技術(shù)保證;它將帶動(dòng)教育管理信息存儲(chǔ)、訪問(wèn)、更新、傳遞方式的變革,進(jìn)一步減輕學(xué)校人力資源和財(cái)政管理的負(fù)擔(dān)。

CNMARC是在UNI-MARC(國(guó)際通用MARC)的基礎(chǔ)上發(fā)展起來(lái)的,它有479個(gè)字段,這些字段是針對(duì)能著錄多種文獻(xiàn)類型及多文種文獻(xiàn)而制定的,數(shù)據(jù)格式結(jié)構(gòu)復(fù)雜繁多,使用時(shí),用其所有字段,只需結(jié)合著錄的文獻(xiàn)類型與文種等實(shí)際情況選擇適用的機(jī)讀目錄格式字段形成數(shù)據(jù)。

中圖法全稱是《中國(guó)圖書館分類法》,是我國(guó)建國(guó)后編制出版的一部具有代表性的大型綜合性分類法。其編制始于1971年,先后出版了四版。自1999年第四版起更名為《中國(guó)圖書館分類法》,簡(jiǎn)稱不變,英文譯名為ChineseLibraryClassification,英文縮寫為CLC。由于國(guó)家圖書館1975年以后的文獻(xiàn)(善本除外)都采用中圖分類法,館藏目錄檢索系統(tǒng)也提供“中圖分類號(hào)”檢索字段,了解中圖分類法有助于讀者準(zhǔn)確地查詢到需要的文獻(xiàn)資源

2、開(kāi)發(fā)工具及所采用的數(shù)據(jù)存放格式要求先進(jìn)

有些人認(rèn)為只要看看功能和界面是否令人滿意就行了,其他的與我們沒(méi)有多少關(guān)系,實(shí)際上開(kāi)發(fā)工具及方式和數(shù)據(jù)格式的存放方式?jīng)Q定了系統(tǒng)的穩(wěn)定性和性能以及未來(lái)的可升級(jí)維護(hù)性。目前國(guó)內(nèi)絕大多數(shù)系統(tǒng)在Windows下運(yùn)行,最先進(jìn)流行的開(kāi)發(fā)工具是美國(guó)Borland公司的Delphi及Microsoft公司的VC++,后臺(tái)數(shù)據(jù)庫(kù)一般采用微軟的SQLServer或Sybase大型數(shù)據(jù)庫(kù)產(chǎn)品。

3、功能是否強(qiáng)大

目前,一般主流的系統(tǒng)包括系統(tǒng)管理、讀者管理、編目、流通、統(tǒng)計(jì)、查詢等功能。比較先進(jìn)的能夠在一個(gè)界面下實(shí)現(xiàn)圖書、音像、期刊的管理,設(shè)置假期、設(shè)置暫離鎖(提高安全性)、暫停某些讀者的借閱權(quán)、導(dǎo)入導(dǎo)出讀者、交換MARC數(shù)據(jù)、升級(jí)輔助編目庫(kù)等。此外,由于學(xué)校校園網(wǎng)絡(luò)的逐步建立,一個(gè)完善的系統(tǒng)還應(yīng)提供無(wú)縫接入校園網(wǎng)的WEB功能,通過(guò)IE瀏覽器讓讀者使用借閱資料查詢、更換密碼、預(yù)約、資料檢索等功能。有些系統(tǒng)還能提供讀者自助服務(wù),可以開(kāi)放一些客戶機(jī)讓讀者自行管理密碼、查詢自己的借閱史、預(yù)約資料、檢索資料等。

4、要有足夠的安全性

安全性一般涉及到操作權(quán)限控制和數(shù)據(jù)自動(dòng)備份兩方面。主流系統(tǒng)都實(shí)現(xiàn)了由管理員分配各操作員可使用的功能并設(shè)置其密碼,各操作員均需先登錄系統(tǒng)然后再操作各種允許使用的功能。一個(gè)完善的系統(tǒng)還應(yīng)對(duì)各操作員的登錄、退出及重要操作記錄在操作日志中。同時(shí)還應(yīng)提供完善的自動(dòng)備份服務(wù),以實(shí)現(xiàn)數(shù)據(jù)的全自動(dòng)按計(jì)劃備份,從而最大限度地保障您的數(shù)據(jù)安全。

5、要有足夠大的輔助編目庫(kù)

在對(duì)圖書進(jìn)行編目也就是信息采集時(shí),如果我們通過(guò)掃描圖書的ISBN號(hào)條碼就能得到大多數(shù)書的書名、作者、出版社等各種標(biāo)準(zhǔn)信息,則我們的編目準(zhǔn)確性和效率將會(huì)得到極大的提高。這就要求有一個(gè)比較完善的準(zhǔn)確的輔助編目庫(kù)。這也是一個(gè)容易被學(xué)校忽視而軟件開(kāi)發(fā)商有意回避的問(wèn)題。

6、要具有完善的規(guī)則

除了能夠設(shè)置讀者的借閱規(guī)則外,還應(yīng)自動(dòng)實(shí)現(xiàn)一些圖書館界通用的管理規(guī)則,例如有在借資料的讀者是不能被刪除的,有以下情況的讀者是不能借閱的:某類書的借閱數(shù)已達(dá)到最大值、有超期資料、有未繳罰款、被暫停借閱等。

7、簡(jiǎn)單易用

一個(gè)好的系統(tǒng)應(yīng)具有清楚的操作界面,最簡(jiǎn)化的操作過(guò)程。日常工作中操作員通過(guò)手持式條碼閱讀器應(yīng)該可以完成絕大部分工作。需要注意的是有些系統(tǒng)將精力花在華麗的界面上,而忽視了用戶真正需要的是實(shí)用的完善的功能。

8、有先進(jìn)的體系結(jié)構(gòu)

當(dāng)前主流系統(tǒng)采用客戶機(jī)服務(wù)器(Client/Server)+瀏覽器/服務(wù)器(Browser/Server)模式,所有信息均存放在數(shù)據(jù)庫(kù)服務(wù)器上,各客戶機(jī)通過(guò)網(wǎng)絡(luò)與數(shù)據(jù)庫(kù)服務(wù)器通訊,WEB服務(wù)通過(guò)ADO模型訪問(wèn)數(shù)據(jù)庫(kù)服務(wù)器,數(shù)據(jù)與應(yīng)用安全地隔離,可確保數(shù)據(jù)存放的安全性。當(dāng)然在具體選擇中還需考慮是否得到主管部門例如省電教館等推薦及性價(jià)比等。

隨著數(shù)字化技術(shù)的飛速發(fā)展,人類正邁向一個(gè)以數(shù)字化技術(shù)革命為中心的新時(shí)代。這一新時(shí)代最明顯的特征便是全球范圍內(nèi)的網(wǎng)絡(luò)革命。這場(chǎng)革命催生出的數(shù)字化信息網(wǎng)絡(luò),大大改善了我們所處的信息環(huán)境,信息的類型和形式變得更加復(fù)雜,人類信息傳播的途徑及獲取信息的方法,都發(fā)生了前所未有的變化,它不僅改變了圖書館信息服務(wù)的方式,同時(shí)也對(duì)圖書館的情報(bào)用戶提出了嚴(yán)峻的挑戰(zhàn)。

三、圖書管理系統(tǒng)現(xiàn)代化程度的標(biāo)準(zhǔn)

1、信息資源收集的現(xiàn)代化

現(xiàn)代社會(huì)信息資源豐富,信息污染也很嚴(yán)重,給圖書館信息資源的收集帶來(lái)了極大麻煩。傳統(tǒng)圖書館時(shí)期,由于各種信息資源極大部分由正規(guī)渠道獲得,經(jīng)過(guò)圖書期刊編輯人員的認(rèn)真校對(duì),信息質(zhì)量相對(duì)可靠。而現(xiàn)代化信息的載體以及出版發(fā)行方式發(fā)生了很大變化,各種光盤、印刷品、網(wǎng)上信息、聲像讀物等良莠不齊。這就要求圖書館采編人員掌握多方面的信息源,運(yùn)用現(xiàn)代化的各種手段,對(duì)各種信息做出盡可能正確的判斷

2、信息加工整理的現(xiàn)代化

在傳統(tǒng)圖書館時(shí)期,文獻(xiàn)資源的分類加工整理比較簡(jiǎn)單,所揭示的文獻(xiàn)信息深度有限,對(duì)文獻(xiàn)的內(nèi)在性質(zhì)、內(nèi)容的揭示基本沒(méi)有。圖書館應(yīng)用計(jì)算機(jī)進(jìn)行分類編目,給文獻(xiàn)內(nèi)容的揭示帶來(lái)了一定的改進(jìn),但無(wú)實(shí)際性的改革。計(jì)算機(jī)所具有的快速處理數(shù)據(jù)的能力遠(yuǎn)遠(yuǎn)沒(méi)有發(fā)揮出來(lái)。信息加工的目的是為了使信息資源有序化,以便于更好地查找和使用文獻(xiàn)信息,如果在文獻(xiàn)信息加工整理上不能實(shí)現(xiàn)統(tǒng)一標(biāo)準(zhǔn)的規(guī)范,圖書館現(xiàn)代化的物質(zhì)基礎(chǔ)就不存在

3、圖書館服務(wù)的現(xiàn)代化

服務(wù)是圖書館的生命。圖書館所做的一切工作,只有一個(gè)目的,就是做好圖書館的讀者服務(wù)工作。服務(wù)的現(xiàn)代化包括兩個(gè)方面,一是圖書館工作人員服務(wù)的現(xiàn)代化,二是服務(wù)手段的現(xiàn)代化。

觀念的現(xiàn)代化要求我們改變?cè)瓉?lái)重管理輕服務(wù)的思想,把以讀者為中心真正落到實(shí)處,發(fā)揮圖書館工作人員的主觀能動(dòng)性,積極收集各種文獻(xiàn)信息資源。在現(xiàn)代化圖書館時(shí)期,判斷一個(gè)圖書館的大小是以圖書館獲取信息的能力,提供服務(wù)的能力來(lái)決定的由于現(xiàn)代化的圖書館是一個(gè)有機(jī)的網(wǎng)絡(luò),各種信息資源許多都是公開(kāi)的、共享的.只要有一定的專業(yè)技能和一切以讀者為中心的服務(wù)觀念,圖書館的服務(wù)工作可以比傳統(tǒng)時(shí)期有一個(gè)質(zhì)的飛躍。

判斷服務(wù)手段的現(xiàn)代化也應(yīng)該用“一切以讀者為中心”這一圖書館的服務(wù)宗旨來(lái)判斷。如果圖書館提供的文獻(xiàn)資源必須使用電腦才能得到,這對(duì)讀者來(lái)說(shuō)就是服務(wù)不好,因?yàn)樗囊鬀](méi)有得到滿足。現(xiàn)代化服務(wù)手段真正的含義應(yīng)該是圖書館根據(jù)讀者不同需要,提供適合各種不同類型的服務(wù)方式。

總之,我們通過(guò)對(duì)圖書管理系統(tǒng)的分析,對(duì)管理系統(tǒng)在其他情況下的應(yīng)用,有了一個(gè)基礎(chǔ)性的了解與掌握。同時(shí),對(duì)熱門圖書的科學(xué)管理,進(jìn)一步提高其利用率,不斷滿足讀者日益旺盛的閱讀需要,有著十分積極的現(xiàn)實(shí)意義。

【參考文獻(xiàn)】

[1]顧俐.圖書館圖書管理系統(tǒng)的設(shè)計(jì).《中國(guó)科技信息》.2007.11.

[2]孫麗莉.圖書管理系統(tǒng)論.《中國(guó)科技信息》.2007.1.

[3]馬慧生、王樹(shù)芬.對(duì)我校圖書館數(shù)字化的建議.《桂林航天工業(yè)高等專科學(xué)校學(xué)報(bào)》.2005.10.3.

[4]張霞.數(shù)字圖書管理系統(tǒng)及其相關(guān)技術(shù)探究.《安陽(yáng)大學(xué)學(xué)報(bào):綜合版》.2003.3.

篇2

為了研究用戶模型,首先研究用戶如何使用云平臺(tái)下的圖書檔案管理系統(tǒng),用戶接入到圖書檔案管理系統(tǒng),必須使用終端,通過(guò)網(wǎng)絡(luò)接入。在這個(gè)過(guò)程中,終端呈現(xiàn)異構(gòu)化、復(fù)雜化、多樣化的特征,①終端目前可能使用電視網(wǎng)、電信網(wǎng)和計(jì)算機(jī)網(wǎng)中的任何一網(wǎng),可以通過(guò)WLAN、WWAN、Internet、PLMN、HFC、傳統(tǒng)CATV、Ethernet和OAN中任何一網(wǎng),隨著時(shí)代和科技的發(fā)展也可能使用其他網(wǎng)絡(luò),其網(wǎng)絡(luò)方面的特征呈現(xiàn)異構(gòu)化、多樣化;②終端類型和型號(hào)都很多,其功能、用途等明顯不同,造成構(gòu)造的不同和復(fù)雜化;終端和網(wǎng)絡(luò)的異構(gòu)化、復(fù)雜化、多樣化,造成了其效果差異化很大,主要體現(xiàn)在:①顯示效果方面;②音效效果方面;③網(wǎng)絡(luò)方面;④計(jì)算復(fù)雜度方面;⑤可用空間方面。從顯示效果的角度來(lái)看,需要注意以下幾點(diǎn):①終端不同,其顯示屏幕的大小不同,從這個(gè)角度來(lái)說(shuō),手機(jī)和電視的差距是最為顯著的之一,筆記本、PC等終端設(shè)備屏幕往往適中,顯示屏幕大小的不同一方面和用戶持有終端是否便利有關(guān),另一方面關(guān)系著用戶瀏覽信息資源時(shí)屏幕的尺寸和效果。②終端不同,其顯示所使用的分辨率不同,體現(xiàn)為顯示時(shí)的效果明顯不同,如顯示時(shí)的清晰細(xì)膩程度、拍照取景和視頻播放的效果等等,而且部分終端的分辨率是固定不變的,無(wú)法進(jìn)行調(diào)節(jié)。③文件的格式不同,其顯示效果可能不同,例如常見(jiàn)的視頻格式有AVI、MPEG、DIVX、MOV、ASF、WMV、RM等,不同的格式記錄相同的視頻信息,其顯示效果也可能完全不同。④顯示效果的程度決定了用戶視覺(jué)角度質(zhì)量的高低,其對(duì)于文本、圖片、圖像、單一的視頻是有決定性作用的,同時(shí)對(duì)多媒體信息資源的效果也是有一定影響的。⑤顯示效果的程度所帶來(lái)的影響,對(duì)于不同的用戶是不同的,其高度影響高度依賴視覺(jué)的用戶,但當(dāng)用戶不依賴于視覺(jué)的時(shí)候影響則不大。從音效效果方面來(lái)看,需要注意以下幾點(diǎn):①終端硬件不同,其發(fā)聲所用的效果不同,即使終端硬件相同其發(fā)聲的效果也可能不同,例如一臺(tái)筆記本電腦,如果其聲卡是集成的則往往沒(méi)有獨(dú)立的聲卡效果好,同樣不同廠商所生產(chǎn)的聲卡效果往往也有一定的差別,不同時(shí)間、不同技術(shù)所生產(chǎn)的聲卡效果也往往不同,但音效效果在設(shè)備、設(shè)置、播放內(nèi)容等完全相同的前提下是一致的。②不同的音頻文件,其效果可能不同,首先數(shù)字音頻技術(shù)指標(biāo)采樣率、壓縮率、比特率、量化級(jí),分別控制單位時(shí)間內(nèi)波形采樣的數(shù)據(jù)數(shù)量、音樂(lè)文件壓縮前后大小的比值、記錄每記錄音頻數(shù)據(jù)一秒鐘所消耗的比特值的平均值、用多少位二進(jìn)制的數(shù)據(jù)描述的聲音波形;其次,不同的音頻文件格式不同,其音效的效果也可能不同,常見(jiàn)的音頻文件格式有WAV、MP3、WMA、OGG、APE等。③對(duì)于部分終端來(lái)說(shuō),音效效果是可以調(diào)節(jié)的,但依然存在音效無(wú)法調(diào)節(jié)的終端。④音頻效果的程度所帶來(lái)的影響,對(duì)于不同的用戶是不同的,其高度影響高度依賴聽(tīng)覺(jué)的用戶,但當(dāng)用戶不依賴于聽(tīng)覺(jué)的時(shí)候影響則不大。從網(wǎng)絡(luò)的角度來(lái)看,①目前大部分的電視網(wǎng)依然是單向的,也就是說(shuō)存在單向和雙向的問(wèn)題,雖然隨著時(shí)代的發(fā)展和技術(shù)的進(jìn)步,單向和雙向的問(wèn)題最終會(huì)被解決,但是目前一段來(lái)說(shuō)其依然是問(wèn)題的一部分。②網(wǎng)絡(luò)不同登陸方式可能不同,例如如果用戶借助電信網(wǎng)登陸和使用服務(wù)有兩種模式,其一是通過(guò)以點(diǎn)播為基礎(chǔ)的短信息服務(wù),需要利用短信服務(wù)的平臺(tái)來(lái)傳輸信息,由于其平臺(tái)經(jīng)常是第三方提供的,因而實(shí)時(shí)性往往較差;第二種方式則是通過(guò)GPRS網(wǎng)絡(luò),這種方案的缺點(diǎn)是覆蓋率較差、傳輸速度低、費(fèi)用高,但可以實(shí)現(xiàn)實(shí)時(shí)。從計(jì)算復(fù)雜度方面來(lái)看,終端之間的差異很大,以電視網(wǎng)的機(jī)頂盒和電視機(jī)來(lái)說(shuō),即使運(yùn)行一個(gè)非常簡(jiǎn)單的動(dòng)畫也會(huì)非常困難,而相同的困擾在計(jì)算機(jī)上往往不存在,換句話說(shuō)計(jì)算復(fù)雜度高的資源無(wú)法在部分終端上運(yùn)行,但同時(shí)部分終端上如果使用計(jì)算復(fù)雜度低的文件則也會(huì)浪費(fèi)資源。從某種程度上來(lái)說(shuō),不同的終端適合使用的信息資源在內(nèi)容、格式等方面是完全不同的。從可用空間的角度看,如果可用空間的大小無(wú)法支持對(duì)應(yīng)的操作,則后續(xù)的操作無(wú)法進(jìn)行,同時(shí)可用空間較小也會(huì)在一定程度上降低運(yùn)算速度。對(duì)于可用空間的大小,不同的用戶可能會(huì)有不同的定義,部分用戶可能對(duì)終端的最小可用空間有自己的要求;還有一部分人對(duì)最小可用空間沒(méi)有要求,但是最小可用空間不夠用的時(shí)候會(huì)有自己期望的行為和操作。

1.2用戶行為研究

用戶的行為,①指用戶使用云平臺(tái)下圖書檔案管理系統(tǒng)的行為,其根據(jù)用戶的身份、目的、習(xí)慣、興趣等不同而不同,用戶可能是進(jìn)行檢索、獲得、修改、保存信息資源,也可能是對(duì)圖書檔案管理系統(tǒng)的管理,如計(jì)費(fèi)等;既包括其行為的種類、參數(shù),同時(shí)還應(yīng)該包括其行為所導(dǎo)致的結(jié)果。②用戶的行為受到其本身的制約,既要受到其身份影響,又受到其興趣和目的影響,但最終通過(guò)行為表現(xiàn)出來(lái),可以通過(guò)用戶的行為獲得用戶的信息,并做出調(diào)整,以便更精確地認(rèn)識(shí)和了解用戶。

1.3用戶偏好研究

用戶偏好,指用戶在考慮服務(wù)或者商品的時(shí)候按照其自身意愿所做出的帶有傾向性的符合理性的選擇,是用戶理性、認(rèn)知和心理感受權(quán)衡后的綜合結(jié)論,是用戶個(gè)性化的體現(xiàn)。在云計(jì)算平臺(tái)下的圖書檔案管理系統(tǒng)中,其可以作為個(gè)性化服務(wù)推薦的基礎(chǔ),主要包括以下幾個(gè)方面的內(nèi)容,①由終端、網(wǎng)絡(luò)等帶來(lái)的與視頻、音頻、可用空間等有關(guān)的偏好信息,此偏好信息用于確認(rèn)用戶偏好的信息資源的模態(tài)類信息,在此類偏好中用戶往往偏愛(ài)一種或者幾種終端,同時(shí)對(duì)于不同終端參數(shù)設(shè)置有不同的偏好;②用戶偏好的信息資源內(nèi)容方面的信息,包括學(xué)科、方向、難度等,這種偏好主要來(lái)源于用戶原有的背景如職業(yè)、專業(yè)、知識(shí)層次等,并隨著用戶的發(fā)展而改變;③其他偏好,主要包括終端、所途經(jīng)的網(wǎng)絡(luò)、所在的位置等;④用戶ID,用以唯一地標(biāo)識(shí)和區(qū)別用戶。

2用戶模型研究

2.1用戶基本信息模型

根據(jù)對(duì)用戶、終端、網(wǎng)絡(luò)的研究,建立用戶基本信息模型,包括三類信息,分別是用戶信息、終端信息和網(wǎng)絡(luò)信息(詳見(jiàn)圖1)。其一是用戶信息如用戶ID、姓名、身份、年齡、知識(shí)層次、密碼、密碼提示問(wèn)題、組別,其中①用戶ID、密碼是不可以省略的,其需要在用戶登陸的時(shí)候確定用戶的基礎(chǔ)信息,同時(shí)用戶ID對(duì)于整個(gè)系統(tǒng)來(lái)說(shuō)是唯一的,也就是說(shuō)所有用戶的ID是沒(méi)有重復(fù)的,是“獨(dú)一無(wú)二”的;②身份、年齡、知識(shí)層次三項(xiàng)可以用于輔助確定用戶的身份,以便在后續(xù)用戶偏好模型未獲得具體信息之前初步判斷和獲得用戶的偏好信息,但鑒于部分用戶的特殊性某些情況下是允許被省略的;③用戶信息可以通過(guò)組別確定用戶的權(quán)限的確認(rèn)。其二是終端信息包括終端ID、終端參數(shù)等,其中①終端ID用于確定接入和登陸到圖書檔案系統(tǒng)的終端的身份,通過(guò)檢索對(duì)應(yīng)于終端的數(shù)據(jù)表可以獲得包括其使用者、終端的類型、終端的基本參數(shù)及范圍、終端的可能配置等的信息,可以初步確定終端的信息;②終端參數(shù)包括的是顯示參數(shù)、音效參數(shù)、計(jì)算復(fù)雜度參數(shù)、可用空間參數(shù),顯示參數(shù)和音效參數(shù)分別是用戶提供的其習(xí)慣使用的顯示、音效參數(shù)的設(shè)置,而計(jì)算復(fù)雜度參數(shù)需要通過(guò)終端ID判斷用戶終端的具體計(jì)算復(fù)雜度獲得,可用空間則需要在圖書檔案系統(tǒng)運(yùn)行的時(shí)候通過(guò)其與終端之間的通訊獲得;③終端信息中終端ID是不可以缺省的,但終端參數(shù)是可以缺省的,在缺省的狀態(tài)下,系統(tǒng)依然可以通過(guò)終端ID獲得終端的類型及基礎(chǔ)的參數(shù)范圍,再根據(jù)參數(shù)范圍進(jìn)行其他的判斷,同時(shí)由于計(jì)算復(fù)雜度參數(shù)和可用空間參數(shù)不需要用戶提供,因而也可以在缺省的情況下獲得。其三則是網(wǎng)絡(luò)信息如網(wǎng)絡(luò)類型、常見(jiàn)位置等,其中①電視網(wǎng)的單雙向問(wèn)題可能會(huì)帶來(lái)新的問(wèn)題需要給予重點(diǎn)關(guān)注;②常見(jiàn)位置,是用戶通常使用終端接入和使用圖書檔案管理系統(tǒng)服務(wù)的位置;③網(wǎng)絡(luò)ID,用以唯一地標(biāo)識(shí)和區(qū)別網(wǎng)絡(luò)。關(guān)于用戶基本信息模型,需要注意的有:①用戶基本信息模型雖然是由三個(gè)部分組成的,但是其是一個(gè)整體,可以通過(guò)數(shù)據(jù)庫(kù)表示出來(lái),其中的每一條記錄都只說(shuō)明的是在某一種情況下用戶使用某種終端通過(guò)某種網(wǎng)絡(luò)接入和使用圖書檔案管理系統(tǒng)的具體設(shè)置以及由此而來(lái)的各種參數(shù),每個(gè)用戶的具體信息可以不只一條而是若干條記錄的組合。②用戶基本信息模型的三個(gè)子模型,可以通過(guò)一個(gè)數(shù)據(jù)表體現(xiàn),也可以分成用戶信息表、終端信息表、網(wǎng)絡(luò)信息表三個(gè)數(shù)據(jù)表的組合來(lái)實(shí)現(xiàn)。

2.2用戶行為模型

用戶行為模型,主要用于記錄用戶的行為、狀態(tài)等信息,其由用戶ID、用戶行為、行為參數(shù)、狀態(tài)參數(shù)三個(gè)部分組成,其中①用戶的行為用于記錄用戶狀態(tài)變化的原因,同時(shí)可以從中獲得用戶基本信息模型的部分信息,同時(shí)也可以完善用戶偏好模型;②用戶行為參數(shù)用于說(shuō)明用戶行為的細(xì)節(jié),是用戶行為有機(jī)的補(bǔ)充;③狀態(tài)參數(shù),用于表明經(jīng)過(guò)用戶的行為之后用戶的變化。

2.3用戶偏好模型

用戶偏好模型是用戶服務(wù)推薦的基礎(chǔ),其主要包括3個(gè)方向,其一是對(duì)所獲取資源的模態(tài)傾向性,是與終端相關(guān)的,其中包括格式、顯示性能、音效性能等,其大多數(shù)屬性是范圍;其二則是對(duì)信息資源內(nèi)容的傾向性,主要包括用戶的身份、年齡、知識(shí)層次、專業(yè)等;其三則是用戶通常所在的位置區(qū)域,可以用于以就近原則對(duì)其提供服務(wù)。

3關(guān)鍵技術(shù)分析

3.1用戶模型應(yīng)用研究

從用戶登陸并使用系統(tǒng)服務(wù)的角度看用戶模型,用戶通過(guò)終端接入計(jì)算機(jī)網(wǎng)、電信網(wǎng)和電視網(wǎng)三網(wǎng)中的一網(wǎng),可以利用一體化標(biāo)識(shí)網(wǎng)絡(luò)技術(shù)連接到系統(tǒng),通過(guò)終端ID確定終端的身份(終端信息模型),通過(guò)終端所在的位置、IP等可以獲得對(duì)應(yīng)的網(wǎng)絡(luò)信息(網(wǎng)絡(luò)信息模型),通過(guò)用戶ID和密碼登陸系統(tǒng)進(jìn)而系統(tǒng)可以確定登陸的用戶(用戶信息模型),如果需要調(diào)用用戶偏好模型可以根據(jù)用戶ID在用戶偏好模型中檢索相應(yīng)的記錄則找到對(duì)應(yīng)用戶偏好的信息(用戶偏好模型),用戶使用過(guò)程中會(huì)有所操作記錄下用戶ID、相關(guān)操作及對(duì)應(yīng)參數(shù)則可以將信息添加到用戶行為模型,根據(jù)用戶ID可以從用戶行為模型獲取相關(guān)的參數(shù)則可以獲得對(duì)應(yīng)信息據(jù)此可以修改和完善其他模型。對(duì)于用戶模型的應(yīng)用,本文認(rèn)為:①對(duì)于信息資源的檢索和使用,既涉及到用戶對(duì)信息資源模態(tài)的偏好,又要涉及到用戶對(duì)信息資源內(nèi)容的偏好,同時(shí)還涉及到用戶所使用的終端;在檢索的時(shí)候首先要根據(jù)終端信息模型和網(wǎng)絡(luò)信息模型判斷終端和網(wǎng)絡(luò)的特性,獲得支持的模態(tài)的信息,獲得顯示、音效、網(wǎng)絡(luò)、計(jì)算復(fù)雜度、可用空間等信息,再根據(jù)這些信息和模態(tài)結(jié)合結(jié)合用戶的偏好以集合的形式進(jìn)行交的運(yùn)算進(jìn)而縮小可以接受的信息資源的模態(tài)范圍并將其作為用戶即時(shí)信息資源模態(tài)的偏好,再通過(guò)用戶偏好模型內(nèi)容傾向類偏好可以獲得用戶對(duì)信息資源內(nèi)容的偏好。②顯示、音效、網(wǎng)絡(luò)、計(jì)算復(fù)雜度、可用空間等的變化會(huì)帶來(lái)很多不同的情況,需要形成對(duì)應(yīng)的策略,該策略既要符合用戶的意愿,又要符合運(yùn)營(yíng)商等商家的利益,同時(shí)必須符合法律法規(guī)并受到相關(guān)部門的監(jiān)管。在實(shí)踐的過(guò)程中,可以設(shè)置相應(yīng)的閾值來(lái)劃分對(duì)應(yīng)的范圍,根據(jù)閾值與當(dāng)前值差別的組合來(lái)判斷當(dāng)前所處的情況,當(dāng)差距過(guò)大或者達(dá)到閾值的時(shí)候可以按照對(duì)應(yīng)的既定策略采取行動(dòng),如在許可的情況下重新生成對(duì)應(yīng)的信息資源、只發(fā)送部分信息資源、壓縮等。③用戶基本信息模型中用戶信息模型、終端信息模型和網(wǎng)絡(luò)信息模型需要相互結(jié)合,是一個(gè)有機(jī)的整體,在使用的時(shí)候相互輔助;同時(shí)用戶基本信息模型、用戶行為模型和用戶偏好模型也是一個(gè)有機(jī)整體,其通過(guò)用戶ID彼此關(guān)聯(lián)。用戶ID在整個(gè)模型中是唯一的,其作用是唯一地標(biāo)識(shí)一個(gè)用戶,以便與其他用戶區(qū)別。

3.2用戶模型的初始化與完善

本文認(rèn)為用戶模型的初始化信息可以從以下幾個(gè)方面獲得:①用戶注冊(cè)的信息②利用調(diào)查研究等方式從側(cè)面獲得的用戶信息;③利用公眾的大眾化特征獲得,其實(shí)質(zhì)是首先獲得用戶基礎(chǔ)信息模型,然后再?gòu)挠脩艋A(chǔ)信息模型獲取數(shù)據(jù),以基礎(chǔ)信息模型數(shù)據(jù)為基礎(chǔ)結(jié)合概率歸類和整理,去生成用戶偏好模型和用戶行為模型的初始數(shù)據(jù)。本文認(rèn)為用戶模型的信息完善與補(bǔ)充,是一個(gè)不斷學(xué)習(xí)和修正的動(dòng)態(tài)反饋過(guò)程,通過(guò)機(jī)器學(xué)習(xí)對(duì)參數(shù)的重新估計(jì)和修正提高了預(yù)測(cè)的精度,進(jìn)而提高服務(wù)的質(zhì)量,可以為個(gè)性化服務(wù)推薦打下基礎(chǔ)。其實(shí)質(zhì)是通過(guò)訓(xùn)練來(lái)逐漸完善用戶行為模型,再根據(jù)用戶行為模型逐步完善用戶基礎(chǔ)信息模型和用戶偏好模型。具體的實(shí)現(xiàn)上,本文認(rèn)為①用戶行為模型可以作為執(zhí)行單元,學(xué)習(xí)單元通過(guò)用戶行為模型提供的信息根據(jù)用戶基本信息模型和用戶偏好模型建立并改進(jìn)知識(shí)庫(kù),執(zhí)行單元格局知識(shí)庫(kù)中的知識(shí)執(zhí)行任務(wù),再將執(zhí)行后的信息反饋到用戶行為模型作為下一步學(xué)習(xí)的資源。②可以用命令序列作為最小單元描述用戶行為,通過(guò)定義兩個(gè)序列、兩個(gè)狀態(tài)之間的相似度來(lái)代表和判斷行為模式之間、狀態(tài)之間的相似程度;模型工作的時(shí)候,計(jì)算序列相似度來(lái)判斷行為和狀態(tài)的變化。

篇3

第一章對(duì)數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)開(kāi)發(fā)和圖書管理系統(tǒng)進(jìn)行了簡(jiǎn)明的介紹,并分析了開(kāi)發(fā)圖書管理系統(tǒng)所應(yīng)進(jìn)行的工作。

第二章對(duì)數(shù)據(jù)庫(kù)的設(shè)計(jì)和SQL語(yǔ)言的使用進(jìn)行了系統(tǒng)分析,為深入理解數(shù)據(jù)庫(kù)應(yīng)用打下了基礎(chǔ)。

第三章學(xué)習(xí)了具體的開(kāi)發(fā)工具Delphi6.0,對(duì)其數(shù)據(jù)庫(kù)組件,SQL語(yǔ)言在Delphi中的應(yīng)用等數(shù)據(jù)庫(kù)編程關(guān)鍵技術(shù)進(jìn)行了系統(tǒng)的介紹。

第四章分析了圖書管理信息系統(tǒng)的應(yīng)用需求,按照數(shù)據(jù)庫(kù)設(shè)計(jì)理論一步一步地給出了系統(tǒng)需求說(shuō)明書、局部ER圖、全局ER圖、系統(tǒng)關(guān)系模式,子模式,利用MSSQLServer2000建立了數(shù)據(jù)庫(kù)

第五章進(jìn)行了具體的程序設(shè)計(jì),具體劃分了三類用戶的操作權(quán)限,設(shè)計(jì)了了三個(gè)操作界面。實(shí)現(xiàn)了數(shù)據(jù)庫(kù)表的瀏覽,記錄的添加、刪除和修改,報(bào)表的生成,實(shí)現(xiàn)了多數(shù)據(jù)庫(kù)表的連接操作,實(shí)現(xiàn)了多條件查詢和模糊查詢,并靈活實(shí)現(xiàn)了對(duì)不可更新查詢結(jié)果集的更新操作,實(shí)現(xiàn)了主從表操作,實(shí)現(xiàn)了密碼維護(hù)功能,最后,系統(tǒng)還可以導(dǎo)入數(shù)據(jù)庫(kù)以對(duì)任意同結(jié)構(gòu)的數(shù)據(jù)庫(kù)進(jìn)行操作。

設(shè)計(jì)充分利用Delphi6、MSSQLServer2000數(shù)據(jù)庫(kù)技術(shù)的強(qiáng)大力量,提高了編程效率和可靠性。

關(guān)鍵詞:數(shù)據(jù)庫(kù),SQL語(yǔ)言,MSSQLServer,Delphi6,

數(shù)據(jù)庫(kù)組件,圖書管理,窗體,listview組件

目錄

摘要………………………………………………………………………………I

第一章緒論……………………………………………………………………1

§1.1數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)開(kāi)發(fā)簡(jiǎn)介………………………………………………1

§1.2圖書管理系統(tǒng)………………………………………………………4

§1.3本文所做的主要工作……………………………………………………6

第二章數(shù)據(jù)庫(kù)理論基礎(chǔ)…………………………………………………………7

§2.1數(shù)據(jù)庫(kù)系統(tǒng)設(shè)計(jì)及范式分析……………………………………………7

§2.2SQL語(yǔ)言介紹…………………………………………………………………11

2.2.1SQL基礎(chǔ)…………………………………………………………………11

2.2.2SQL語(yǔ)句…………………………………………………………………12

第三章應(yīng)用系統(tǒng)開(kāi)發(fā)工具…………………………………………………16

§3.1Delphi6.0VCL組件的體系結(jié)構(gòu)………………………………………16

§3.2數(shù)據(jù)庫(kù)組件介紹……………………………………………………………17

§3.3SQL語(yǔ)言在Delphi中的應(yīng)用……………………………………………18

§3.4MSSQLServer簡(jiǎn)述……………………………………………………22

第四章圖書管理系統(tǒng)設(shè)計(jì)分析…………………………………………24

§4.1應(yīng)用需求分析……………………………………………………………24

§4.2系統(tǒng)功能模塊劃分………………………………………………………29

§4.3系統(tǒng)數(shù)據(jù)庫(kù)設(shè)計(jì)…………………………………………………………29

第五章圖書管理系統(tǒng)應(yīng)用程序設(shè)計(jì)……………………………………37

§5.1系統(tǒng)窗體模塊組成…………………………………………………………37

§5.2數(shù)據(jù)模塊窗體的設(shè)置………………………………………………………37

§5.3啟動(dòng)畫面的實(shí)現(xiàn)……………………………………………………………38

§5.4用戶登錄窗體的的實(shí)現(xiàn)………………………………………………………39

§5.5用戶密碼認(rèn)證窗體的的實(shí)現(xiàn)…………………………………………………39

§5.6借閱者服務(wù)模塊的實(shí)現(xiàn)……………………………………………………40

5.6.1圖書查詢功能的實(shí)現(xiàn)…………………………………………………41

5.6.2借閱者登錄功能的實(shí)現(xiàn)…………………………………………………42

5.6.3借閱者借閱情況功能的實(shí)現(xiàn)……………………………………………43

5.6.4借閱者個(gè)人資料維護(hù)功能的實(shí)現(xiàn)………………………………………47

§5.7工作人員-圖書借閱/歸還模塊的實(shí)現(xiàn)………………………………………49

5.7.1工作人員進(jìn)行圖書借閱功能實(shí)現(xiàn)………………………………………50

5.7.2工作人員進(jìn)行圖書歸還功能實(shí)現(xiàn)………………………………………53

§5.8圖書館管理員模塊的實(shí)現(xiàn)……………………………………………54

5.8.1圖書館管理員圖書管理功能的實(shí)現(xiàn)……………………………………55

5.8.2圖書館管理員工作人員和管理員管理功能的實(shí)現(xiàn)……………………58

5.8.3圖書館管理員修改圖書類別及統(tǒng)記功能的實(shí)現(xiàn)………………………60

5.8.4圖書館管理員借閱者管理功能的實(shí)現(xiàn)…………………………………62

5.8.5圖書館維護(hù)借閱者管理功能的實(shí)現(xiàn)…………………………………62

5.8.6圖書館身份維護(hù)功能的實(shí)現(xiàn)………………………………………64

5.8.7圖書館借閱者統(tǒng)計(jì)功能的實(shí)現(xiàn)…………………………………65

5.8.8圖書館統(tǒng)計(jì)借閱過(guò)期記錄功能的實(shí)現(xiàn)…………………………67

§5.9系統(tǒng)信息顯示的實(shí)現(xiàn)…………………………………………………68

第六章結(jié)束語(yǔ)………………………………………………………………69

致謝………………………………………………………………………………70

參考書目……………………………………………………………………………70

第一章緒論

§1.1數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)開(kāi)發(fā)簡(jiǎn)介

在數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)開(kāi)發(fā)之前,對(duì)開(kāi)發(fā)數(shù)據(jù)庫(kù)的基本概念應(yīng)當(dāng)了解,對(duì)數(shù)據(jù)庫(kù)的結(jié)構(gòu)、開(kāi)發(fā)數(shù)據(jù)庫(kù)應(yīng)用程序的步驟、開(kāi)發(fā)體系及方法都應(yīng)當(dāng)有相當(dāng)清晰的了解和認(rèn)識(shí)。

數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)開(kāi)發(fā)的目標(biāo)是建立一個(gè)滿足用戶長(zhǎng)期需求的產(chǎn)品。開(kāi)發(fā)的主要過(guò)程為:理解用戶的需求,然后,把它們轉(zhuǎn)變?yōu)橛行У臄?shù)據(jù)庫(kù)設(shè)計(jì)。把設(shè)計(jì)轉(zhuǎn)變?yōu)閷?shí)際的數(shù)據(jù)庫(kù),并且這些數(shù)據(jù)庫(kù)帶有功能完備、高效能的應(yīng)用。

數(shù)據(jù)庫(kù)技術(shù)在計(jì)算機(jī)軟件鄰域研究中一直是非常重要的主題,產(chǎn)生于60年代,30多年來(lái)數(shù)據(jù)庫(kù)技術(shù)得到了迅速發(fā)展,并已形成較為完整的理論體系和一大批實(shí)用系統(tǒng)。并且,近年來(lái),隨著WorldWideWeb(WWW)的猛增及Internet技術(shù)的迅速發(fā)展,使得數(shù)據(jù)庫(kù)技術(shù)之時(shí)成為最熱門技術(shù)之一。

1.1.1數(shù)據(jù)庫(kù)

如圖1.1顯示了數(shù)據(jù)庫(kù)系統(tǒng)的主要組件。數(shù)據(jù)庫(kù)由DBMS(數(shù)據(jù)庫(kù)管理系統(tǒng))處理,DBMS則由開(kāi)發(fā)人員和用戶通過(guò)應(yīng)用程序直接或間接地使用。它主要包括四個(gè)要素:用戶數(shù)據(jù)、元數(shù)據(jù)、索引和應(yīng)用元數(shù)據(jù)。

1.1.1.1用戶數(shù)據(jù)

目前,大多數(shù)主流數(shù)據(jù)庫(kù)管理系統(tǒng)把用戶數(shù)據(jù)表示為關(guān)系。現(xiàn)在把關(guān)系看作數(shù)據(jù)表。表的列包含域或?qū)傩裕淼男邪瑢?duì)應(yīng)業(yè)務(wù)環(huán)境中的實(shí)體的記錄。并非所有的關(guān)系都同樣符合要求,有些關(guān)系比其它關(guān)系更結(jié)構(gòu)化一些。第二章描述了一個(gè)用以產(chǎn)生良好結(jié)構(gòu)關(guān)系的過(guò)程,稱作規(guī)范化。

為了對(duì)比結(jié)構(gòu)差的關(guān)系和結(jié)構(gòu)好的關(guān)系之間的差別,以本文所設(shè)計(jì)的圖書管理系統(tǒng)中的圖書和圖書借閱者關(guān)系為例來(lái)說(shuō)明,假若設(shè)計(jì)關(guān)系R1(借書證號(hào),姓名,性別,身份編號(hào),身份證,聯(lián)系電話,圖書編號(hào),圖書名稱,圖書類別,作者,出版社,出版日期,備注,價(jià)格,數(shù)量);這個(gè)關(guān)系的問(wèn)題出在它有關(guān)于兩個(gè)不同主題的數(shù)據(jù),就是圖書借閱者和圖書。用這種方式構(gòu)成的關(guān)系在進(jìn)行修改時(shí),會(huì)出現(xiàn)問(wèn)題。因?yàn)橐粋€(gè)圖書借閱者可能借閱多本書,如果某個(gè)圖書借閱者的某個(gè)字段(如聯(lián)系電話)出現(xiàn)變更,它所借閱的圖書記錄(可能多個(gè))也就必須變化,這是不好的。因此數(shù)據(jù)用兩個(gè)關(guān)系表示更好。現(xiàn)在如果某圖書借閱者改變了它的聯(lián)系電話,只有關(guān)系(表)user的對(duì)應(yīng)行需要改變。當(dāng)然,要想產(chǎn)生一個(gè),顯示圖書名稱及其借閱者聯(lián)系電話的報(bào)表,就需要將這兩個(gè)表的行結(jié)合起來(lái)。結(jié)果表明,將關(guān)系分別存儲(chǔ),在生成報(bào)表的時(shí)候?qū)⑺鼈兘Y(jié)合起來(lái),比把它們存儲(chǔ)在一個(gè)合成的表中更好。

user(借書證號(hào),姓名,性別,身份編號(hào),身份證,聯(lián)系電話,)

book(圖書編號(hào),圖書名稱,圖書類別,作者,出版社,出版日期,備注,價(jià)格,數(shù)量)

1.1.1.2元數(shù)據(jù)

數(shù)據(jù)庫(kù)是自描述的,這就意味著它自身包含了它的結(jié)構(gòu)的描述,這種結(jié)構(gòu)的描述稱作元數(shù)據(jù)。因?yàn)镈BMS產(chǎn)品是用來(lái)存儲(chǔ)和操縱表的,所以大多數(shù)產(chǎn)品把元數(shù)據(jù)以表的形式存儲(chǔ),有時(shí)稱作系統(tǒng)表。這些系統(tǒng)表存儲(chǔ)了數(shù)據(jù)庫(kù)中表的情況,指出每一個(gè)表中有多少列,那一列是主關(guān)鍵字,每一列的數(shù)據(jù)類型的描述,它也存儲(chǔ)索引、關(guān)鍵字、規(guī)則和數(shù)據(jù)庫(kù)結(jié)構(gòu)的其他部分。

在表中存儲(chǔ)元數(shù)據(jù)不僅對(duì)DBMS是有效的,對(duì)用戶也是方便的,因?yàn)樗麄兛梢允褂门c查詢用戶數(shù)據(jù)同樣的查詢工具來(lái)查詢?cè)獢?shù)據(jù)。本文第二章所介紹的SQL語(yǔ)言可以同時(shí)用于元數(shù)據(jù)和用戶數(shù)據(jù)。

1.1.1.3索引

第三種類型的數(shù)據(jù)改進(jìn)了數(shù)據(jù)庫(kù)的性能和可訪問(wèn)性,這種數(shù)據(jù)經(jīng)常稱作開(kāi)銷數(shù)據(jù),盡管有時(shí)也采用其他類型的數(shù)據(jù)結(jié)構(gòu),如鏈表,但它主要還是索引。索引可以用來(lái)排序和快速訪問(wèn)數(shù)據(jù)。下面以本人的圖書管理信息系統(tǒng)中的book表為例來(lái)說(shuō)明。

假定數(shù)據(jù)在磁盤上是按’圖書編號(hào)’的遞增順序排列的,用戶想打印一個(gè)按’圖書名稱’排序的圖書數(shù)據(jù)報(bào)表。為此,所有的數(shù)據(jù)都需要從源表中提取出來(lái)并排序,除非表很小,否則這是一個(gè)很費(fèi)時(shí)的過(guò)程。或者,可以在‘圖書名稱’字段上創(chuàng)建一個(gè)索引,該索引的條目按照‘圖書名稱’排序,這樣,該索引的條目可以讀出來(lái),并用來(lái)按順序訪問(wèn)book數(shù)據(jù)。

索引用于快速訪問(wèn)數(shù)據(jù)。例如,一個(gè)用戶只想訪問(wèn)book表中‘圖書類別’值為‘01’的那些學(xué)生。如果沒(méi)有索引,則必須搜索整個(gè)源表;但有了索引之后,可以找到索引條目,并使用它來(lái)挑選所有合適的行。

索引對(duì)排序和查找是有幫助的,但要付出代價(jià)。book表中的行每次改變時(shí),索引也必須改變,這意味著索引并非隨意的,應(yīng)該在真正需要時(shí)保存。

1.1.1.4應(yīng)用元數(shù)據(jù)

存儲(chǔ)在數(shù)據(jù)庫(kù)中的第四種數(shù)據(jù)是應(yīng)用元數(shù)據(jù),它用來(lái)存儲(chǔ)用戶窗體、報(bào)表、查詢和其他形式的查詢組件。并非所有的DBMS都支持應(yīng)用組件,支持組件的DBMS也不一定把全部組件的結(jié)構(gòu)作為應(yīng)用元數(shù)據(jù)存儲(chǔ)在數(shù)據(jù)庫(kù)中。然而,大多數(shù)現(xiàn)代的DBMS產(chǎn)品存儲(chǔ)這種數(shù)據(jù)作為數(shù)據(jù)庫(kù)的一部分。一般來(lái)說(shuō),數(shù)據(jù)庫(kù)開(kāi)發(fā)人員和用戶都不直接訪問(wèn)應(yīng)用元數(shù)據(jù),想反,他們通過(guò)DBMS中的工具來(lái)處理這些數(shù)據(jù)。

MSSQLServer2000中就支持窗體、存儲(chǔ)過(guò)程等應(yīng)用元數(shù)據(jù)。

1.1.2數(shù)據(jù)庫(kù)管理系統(tǒng)

數(shù)據(jù)庫(kù)管理系統(tǒng)(DBMS)是指數(shù)據(jù)庫(kù)系統(tǒng)中管理數(shù)據(jù)的軟件系統(tǒng)。DBMS是數(shù)據(jù)庫(kù)系統(tǒng)的核心組成部分。對(duì)數(shù)據(jù)庫(kù)的一切操作,包括定義、更新及各種控制,都是通過(guò)DBMS進(jìn)行的。DBMS總是基于某種數(shù)據(jù)模型,可以把DBMS看成是某種數(shù)據(jù)模型在計(jì)算機(jī)系統(tǒng)上的具體實(shí)現(xiàn)。根據(jù)數(shù)據(jù)模型的不同,DBMS可以分成層次型、網(wǎng)狀型、關(guān)系型、面向?qū)ο笮偷取SSQLServer2000就是一種關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)。

關(guān)系模型。關(guān)系模型主要是用二維表格結(jié)構(gòu)表達(dá)實(shí)體集,用外鍵表示實(shí)體間聯(lián)系。關(guān)系模型是由若干個(gè)關(guān)系模式組成的集合。關(guān)系模式相當(dāng)于前面提到的記錄類型,它的實(shí)例稱為關(guān)系,每個(gè)關(guān)系實(shí)際上是一張二維表格。

關(guān)系模型和層次、網(wǎng)狀模型的最大判別是用關(guān)鍵碼而不是用指針導(dǎo)航數(shù)據(jù),表格簡(jiǎn)單用戶易懂,編程時(shí)并不涉及存儲(chǔ)結(jié)構(gòu),訪問(wèn)技術(shù)等細(xì)節(jié)。關(guān)系模型是數(shù)學(xué)化模型。SQL語(yǔ)言是關(guān)系數(shù)據(jù)庫(kù)的標(biāo)準(zhǔn)化語(yǔ)言,已得到了廣泛的應(yīng)用。

如圖1.1所示,DBMS的特點(diǎn)和功能可以分為三個(gè)子系統(tǒng):設(shè)計(jì)工具子系統(tǒng)、運(yùn)行子系統(tǒng)和DBMS引擎。

設(shè)計(jì)子系統(tǒng)有一個(gè)方便數(shù)據(jù)庫(kù)及其應(yīng)用創(chuàng)建的工具集。它典型地包含產(chǎn)生表、窗體、查詢和報(bào)表的工具。DBMS產(chǎn)品還提供編程語(yǔ)言和對(duì)編程語(yǔ)言的接口。

運(yùn)行子系統(tǒng)處理用設(shè)計(jì)子系統(tǒng)開(kāi)發(fā)的應(yīng)用組件。它所包含的運(yùn)行處理器用來(lái)處理窗體和數(shù)據(jù)庫(kù)的數(shù)據(jù)交互,以及回答查詢和打印報(bào)表等。

DBMS引擎從其他兩個(gè)組件接受請(qǐng)求,并把它們翻譯成對(duì)操作系統(tǒng)的命令,以便讀寫物理介質(zhì)上的數(shù)據(jù)。DBMS引擎還涉及事務(wù)管理、鎖、備份和恢復(fù)。

1.1.3創(chuàng)建數(shù)據(jù)庫(kù)

1.1.3.1數(shù)據(jù)庫(kù)模式

數(shù)據(jù)庫(kù)模式定義了數(shù)據(jù)庫(kù)的結(jié)構(gòu)、表、關(guān)系、域和業(yè)務(wù)規(guī)則。數(shù)據(jù)庫(kù)模式是一種設(shè)計(jì),數(shù)據(jù)庫(kù)和應(yīng)用正是建立在此基礎(chǔ)上的。

域是一列可能擁有的值的集合。必須為每一個(gè)表的每一定域。除了數(shù)據(jù)的物理格式外,還需要確定是否有些域?qū)Ρ韥?lái)說(shuō)是唯一的。

數(shù)據(jù)庫(kù)模式的最后一個(gè)要素是業(yè)務(wù)規(guī)則,它是對(duì)需要反映在數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)應(yīng)用程序中的業(yè)務(wù)活動(dòng)的約束。業(yè)務(wù)規(guī)則是模式的一個(gè)重要部分,因?yàn)樗麄冎付藷o(wú)論什么數(shù)據(jù)變化到達(dá)DBMS引擎,允許的數(shù)據(jù)值必須滿足的約束。不管無(wú)效的數(shù)據(jù)變化請(qǐng)求是來(lái)自窗體的用戶、查詢/修改請(qǐng)求還是應(yīng)用程序,DBMS都應(yīng)該拒絕。

遺憾的是,不同的DBMS產(chǎn)品用不同的方法實(shí)施業(yè)務(wù)規(guī)則。在某些情況下,DBMS產(chǎn)品不具備實(shí)施必要業(yè)務(wù)規(guī)則的能力,必須以代碼形式把它們編入應(yīng)用程序。

1.1.3.2創(chuàng)建表

1.1.3.3定義聯(lián)系

1.1.4應(yīng)用組件

數(shù)據(jù)庫(kù)應(yīng)用包括窗體、查詢、報(bào)表、菜單和應(yīng)用程序。

§1.2圖書管理系統(tǒng)

當(dāng)今時(shí)代是飛速發(fā)展的信息時(shí)代。在各行各業(yè)中離不開(kāi)信息處理,這正是計(jì)算機(jī)被廣泛應(yīng)用于信息管理系統(tǒng)的環(huán)境。計(jì)算機(jī)的最大好處在于利用它能夠進(jìn)行信息管理。使用計(jì)算機(jī)進(jìn)行信息控制,不僅提高了工作效率,而且大大的提高了其安全性。

尤其對(duì)于復(fù)雜的信息管理,計(jì)算機(jī)能夠充分發(fā)揮它的優(yōu)越性。計(jì)算機(jī)進(jìn)行信息管理與信息管理系統(tǒng)的開(kāi)發(fā)密切相關(guān),系統(tǒng)的開(kāi)發(fā)是系統(tǒng)管理的前提。本系統(tǒng)就是為了管理好圖書館信息而設(shè)計(jì)的。

圖書館作為一種信息資源的集散地,圖書和用戶借閱資料繁多,包含很多的信息數(shù)據(jù)的管理,現(xiàn)今,有很多的圖書館都是初步開(kāi)始使用,甚至尚未使用計(jì)算機(jī)進(jìn)行信息管理。根據(jù)調(diào)查得知,他們以前對(duì)信息管理的主要方式是基于文本、表格等紙介質(zhì)的手工處理,對(duì)于圖書借閱情況(如借書天數(shù)、超過(guò)限定借書時(shí)間的天數(shù))的統(tǒng)計(jì)和核實(shí)等往往采用對(duì)借書卡的人工檢查進(jìn)行,對(duì)借閱者的借閱權(quán)限、以及借閱天數(shù)等用人工計(jì)算、手抄進(jìn)行。數(shù)據(jù)信息處理工作量大,容易出錯(cuò);由于數(shù)據(jù)繁多,容易丟失,且不易查找。總的來(lái)說(shuō),缺乏系統(tǒng),規(guī)范的信息管理手段。盡管有的圖書館有計(jì)算機(jī),但是尚未用于信息管理,沒(méi)有發(fā)揮它的效力,資源閑置比較突出,這就是管理信息系統(tǒng)的開(kāi)發(fā)的基本環(huán)境。

數(shù)據(jù)處理手工操作,工作量大,出錯(cuò)率高,出錯(cuò)后不易更改。圖書館采取手工方式對(duì)圖書借閱情況進(jìn)行人工管理,由于信息比較多,圖書借閱信息的管理工作混亂而又復(fù)雜;一般借閱情況是記錄在借書證上,圖書的數(shù)目和內(nèi)容記錄在文件中,圖書館的工作人員和管理員也只是當(dāng)時(shí)對(duì)它比較清楚,時(shí)間一長(zhǎng),如再要進(jìn)行查詢,就得在眾多的資料中翻閱、查找了,造成查詢費(fèi)時(shí)、費(fèi)力。如要對(duì)很長(zhǎng)時(shí)間以前的圖書進(jìn)行更改就更加困難了。

基于這此問(wèn)題,我認(rèn)為有必要建立一個(gè)圖書管理系統(tǒng),使圖書管理工作規(guī)范化,系統(tǒng)化,程序化,避免圖書管理的隨意性,提高信息處理的速度和準(zhǔn)確性,能夠及時(shí)、準(zhǔn)確、有效的查詢和修改圖書情況。

§1.1系統(tǒng)所做工作

1)了解應(yīng)用開(kāi)發(fā)工具的現(xiàn)狀

2)DelPHi6.0編程基礎(chǔ)

3)MSSQLServer基礎(chǔ)

4)設(shè)計(jì)數(shù)據(jù)庫(kù);設(shè)計(jì)界面

5)開(kāi)發(fā)數(shù)據(jù)庫(kù)。數(shù)據(jù)庫(kù)實(shí)現(xiàn)的一些功能有

l數(shù)據(jù)和數(shù)據(jù)說(shuō)明的醒目顯示;

l多條件的查詢、多條記錄的檢索、模糊查詢;

l數(shù)據(jù)文件某種存儲(chǔ)格式導(dǎo)入數(shù)據(jù)窗體,經(jīng)過(guò)數(shù)據(jù)完整性校驗(yàn)存入數(shù)據(jù)庫(kù);

l數(shù)據(jù)庫(kù)安全性的設(shè)計(jì);

l數(shù)據(jù)庫(kù)的設(shè)計(jì)、數(shù)據(jù)接口、界面的設(shè)計(jì)。

§1.3本文所作工作

緒論部分對(duì)數(shù)據(jù)庫(kù)應(yīng)用系統(tǒng)的結(jié)構(gòu)、開(kāi)發(fā)進(jìn)行了簡(jiǎn)要介紹,分析了圖書管理信息系統(tǒng)設(shè)計(jì)的特點(diǎn)和任務(wù)。

第二章介紹了數(shù)據(jù)庫(kù)的設(shè)計(jì)和范式分析,并系統(tǒng)介紹了SQL語(yǔ)言,為設(shè)計(jì)和理解應(yīng)用程序做了鋪墊。

第三章對(duì)系統(tǒng)介紹了Delphi6.0的數(shù)據(jù)庫(kù)編程技術(shù)、SQL語(yǔ)言在Delphi6.0中的應(yīng)用、MSSQLServer基礎(chǔ)。

第四章分析了圖書管理系統(tǒng)的應(yīng)用需求,設(shè)計(jì)了系統(tǒng)的數(shù)據(jù)庫(kù)結(jié)構(gòu),并根據(jù)需求對(duì)系統(tǒng)功能進(jìn)行了劃分和細(xì)化。

第五章根據(jù)第四章的設(shè)計(jì)結(jié)果利用MSSQLServer2000和Delphi6.0進(jìn)行了具體的應(yīng)用程序設(shè)計(jì)。

總結(jié)部分介紹了設(shè)計(jì)體會(huì)和編程體會(huì),并指出了系統(tǒng)設(shè)計(jì)中的不足和改進(jìn)的方向。

第二章數(shù)據(jù)庫(kù)理論基礎(chǔ)

一個(gè)成功的信息管理系統(tǒng),是建立在許多條件之上的,而數(shù)據(jù)庫(kù)是其中一個(gè)非常重要的條件和關(guān)鍵技術(shù)。

信息管理系統(tǒng)所涉及的數(shù)據(jù)庫(kù)設(shè)計(jì)分五個(gè)步驟:數(shù)據(jù)庫(kù)需求分析、概念設(shè)計(jì)、邏輯設(shè)計(jì)、物理設(shè)計(jì)與加載測(cè)試。

(1)數(shù)據(jù)庫(kù)需求分析的任務(wù)是將業(yè)務(wù)管理單證流化為數(shù)據(jù)流,劃分主題之間的邊界,繪制出DFD圖,并完成相應(yīng)的數(shù)據(jù)字典。

(2)概念設(shè)計(jì)的任務(wù)是從DFD出發(fā),繪制出本主題的實(shí)體-關(guān)系圖,并列出各個(gè)實(shí)體與關(guān)系的綱要表。

(3)邏輯設(shè)計(jì)的任務(wù)是從E-R圖與對(duì)應(yīng)的綱要表出發(fā),確定各個(gè)實(shí)體及關(guān)系的表名屬性。

(4)物理設(shè)計(jì)的任務(wù)是確定所有屬性的類型、寬度與取值范圍,設(shè)計(jì)出基本表的主鍵,將所有的表名與字段名英文化(現(xiàn)在很多軟件能支持中文字段,如MSSQLServer,我就是用的中文字段名),實(shí)現(xiàn)物理建庫(kù),完成數(shù)據(jù)庫(kù)物理設(shè)計(jì)字典。

(5)加載測(cè)試工作貫穿于程序測(cè)試工作的全過(guò)程,整個(gè)錄入、修改、查詢、處理工作均可視為對(duì)數(shù)據(jù)庫(kù)的加載測(cè)試工作。

要設(shè)計(jì)出一個(gè)好的信息管理系統(tǒng)數(shù)據(jù)庫(kù),除滿足系統(tǒng)所要求的功能外,還必須遵守下列原則:

²基本表的個(gè)數(shù)越少越好。

²主鍵的個(gè)數(shù)越少越好。鍵是表間連接的工具,主鍵越少,表間的連接就越簡(jiǎn)單。

²字段的個(gè)數(shù)越少越好。

²所有基本表的設(shè)計(jì)均應(yīng)盡量符合第三范式。

數(shù)據(jù)庫(kù)的設(shè)計(jì)中,如何處理多對(duì)多的關(guān)系和如何設(shè)計(jì)主鍵,是兩個(gè)有著較大難度、需要重點(diǎn)考慮的問(wèn)題。下面我們著重從SQL應(yīng)用、數(shù)據(jù)庫(kù)設(shè)計(jì)范式和查詢優(yōu)化等方面來(lái)分析本課題的系統(tǒng)關(guān)鍵技術(shù)和實(shí)現(xiàn)難點(diǎn)并加以解決。

§2.1數(shù)據(jù)庫(kù)系統(tǒng)設(shè)計(jì)及范式分析

信息系統(tǒng)的主要任務(wù)是通過(guò)大量的數(shù)據(jù)獲得管理所需要的信息,這就必須存儲(chǔ)和管理大量的數(shù)據(jù)。因此建立一個(gè)良好的數(shù)據(jù)組織結(jié)構(gòu)和數(shù)據(jù)庫(kù),使整個(gè)系統(tǒng)都可以迅速、方便、準(zhǔn)確地調(diào)用和管理所需的數(shù)據(jù),是衡量信息系統(tǒng)開(kāi)發(fā)工作好壞的主要指標(biāo)之一。

2.1.1數(shù)據(jù)庫(kù)系統(tǒng)設(shè)計(jì)

數(shù)據(jù)庫(kù)設(shè)計(jì)主要是進(jìn)行數(shù)據(jù)庫(kù)的邏輯設(shè)計(jì),即將數(shù)據(jù)按一定的分類、分組系統(tǒng)和邏輯層次組織起來(lái),是面向用戶的。數(shù)據(jù)庫(kù)設(shè)計(jì)時(shí)需要綜合企業(yè)各個(gè)部門的存檔數(shù)據(jù)和數(shù)據(jù)需求,分析各個(gè)數(shù)據(jù)之間的關(guān)系,按照DBMS提供的功能和描述工具,設(shè)計(jì)出規(guī)模適當(dāng)、正確反映數(shù)據(jù)關(guān)系、數(shù)據(jù)冗余少、存取效率高、能滿足多種查詢要求的數(shù)據(jù)模型。

數(shù)據(jù)庫(kù)設(shè)計(jì)的步驟是:

(1)數(shù)據(jù)庫(kù)結(jié)構(gòu)定義:目前的數(shù)據(jù)庫(kù)管理系統(tǒng)(DBMS)有的是支持聯(lián)機(jī)事務(wù)處理CLTP(負(fù)責(zé)對(duì)事務(wù)數(shù)據(jù)進(jìn)行采集、處理、存儲(chǔ))的操作型DBMS,有的可支持?jǐn)?shù)據(jù)倉(cāng)庫(kù)、有聯(lián)機(jī)分析處理CLAP(指為支持決策的制定對(duì)數(shù)據(jù)的一種加工操作)功能的大型DBMS,有的數(shù)據(jù)庫(kù)是關(guān)系型的、有的可支持面向?qū)ο髷?shù)據(jù)庫(kù)。針對(duì)選擇的DBMS,進(jìn)行數(shù)據(jù)庫(kù)結(jié)構(gòu)定義。

(2)數(shù)據(jù)表定義:數(shù)據(jù)表定義指定義數(shù)據(jù)庫(kù)中數(shù)據(jù)表的結(jié)構(gòu),數(shù)據(jù)表的邏輯結(jié)構(gòu)包括:屬性名稱、類型、表示形式、缺省值、校驗(yàn)規(guī)則、是否關(guān)鍵字、可否為空等。關(guān)系型數(shù)據(jù)庫(kù)要盡量按關(guān)系規(guī)范化要求進(jìn)行數(shù)據(jù)庫(kù)設(shè)計(jì),但為使效率高,規(guī)范化程度應(yīng)根據(jù)應(yīng)用環(huán)境和條件來(lái)決定。數(shù)據(jù)表設(shè)計(jì)不僅要滿足數(shù)據(jù)存儲(chǔ)的要求,還要增加一些如反映有關(guān)信息、操作責(zé)任、中間數(shù)據(jù)的字段或臨時(shí)數(shù)據(jù)表。

(3)存儲(chǔ)設(shè)備和存儲(chǔ)空間組織:確定數(shù)據(jù)的存放地點(diǎn)、存儲(chǔ)路徑、存儲(chǔ)設(shè)備等,備份方案,對(duì)多版本如何保證一致性和數(shù)據(jù)的完整性。

(4)數(shù)據(jù)使用權(quán)限設(shè)置:針對(duì)用戶的不同使用要求,確定數(shù)據(jù)的用戶使用權(quán)限,確保數(shù)據(jù)安全。

(5)數(shù)據(jù)字典設(shè)計(jì):用數(shù)據(jù)字典描述數(shù)據(jù)庫(kù)的設(shè)計(jì),便于維護(hù)和修改。

為了更好地組織數(shù)據(jù)和設(shè)計(jì)出實(shí)際應(yīng)用數(shù)據(jù)庫(kù),應(yīng)該注意如下問(wèn)題:

規(guī)范化地重組數(shù)據(jù)結(jié)構(gòu):對(duì)數(shù)據(jù)進(jìn)行規(guī)范化表達(dá),這在后面將會(huì)具體討論。

關(guān)系數(shù)據(jù)結(jié)構(gòu)的建立:在進(jìn)行了數(shù)據(jù)基本結(jié)構(gòu)的規(guī)范化重組后,還必須建立整體數(shù)據(jù)的關(guān)系結(jié)構(gòu)。這一步設(shè)計(jì)完成后數(shù)據(jù)庫(kù)和數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)工作基本完成,只待系統(tǒng)實(shí)現(xiàn)時(shí)將數(shù)據(jù)分析和數(shù)據(jù)字典的內(nèi)容代入到所設(shè)計(jì)的數(shù)據(jù)整體關(guān)系結(jié)構(gòu)中,一個(gè)規(guī)范化數(shù)據(jù)庫(kù)系統(tǒng)結(jié)構(gòu)就建立起來(lái)了。

建立關(guān)系數(shù)據(jù)結(jié)構(gòu)涉及三方面內(nèi)容:確定關(guān)聯(lián)的關(guān)鍵指標(biāo)項(xiàng)并建立關(guān)聯(lián)表;確定單一的父系記錄結(jié)構(gòu);建立整個(gè)數(shù)據(jù)庫(kù)的關(guān)系結(jié)構(gòu)。

(1)鏈接關(guān)系的確定

在進(jìn)行了上述數(shù)據(jù)規(guī)范化重組后,已經(jīng)可以確保每一個(gè)基本數(shù)據(jù)表(我們簡(jiǎn)稱為表)是規(guī)范的,但是這些單獨(dú)的表并不能完整地反映事物,通常需要通過(guò)指標(biāo)體系整體指標(biāo)數(shù)據(jù)才能完整全面地反映問(wèn)題。也就是說(shuō)在這些基本表的各宇段中,所存儲(chǔ)的是同一事物不同側(cè)面的屬性。那么計(jì)算機(jī)系統(tǒng)如何能知道哪些表中的哪些記錄應(yīng)與其它表中的哪些記錄相對(duì)應(yīng),它們表示的是同一個(gè)事物呢?這就需要在設(shè)計(jì)數(shù)據(jù)結(jié)構(gòu)時(shí)將這種各表之間的數(shù)據(jù)記錄關(guān)系確定下來(lái)。這種表與表之間的數(shù)據(jù)關(guān)系一般都是通過(guò)主或輔關(guān)鍵詞之間的連接來(lái)實(shí)現(xiàn)的。因?yàn)樵诿總€(gè)表中只有主關(guān)鍵詞才能唯一地標(biāo)識(shí)表中的這一個(gè)記錄值(因?yàn)楦鶕?jù)第三范式的要求,表中其它數(shù)據(jù)字段函數(shù)都依賴于主關(guān)鍵詞),所以將表通過(guò)關(guān)鍵詞連接就能夠唯一地標(biāo)識(shí)出某一事物不同屬性在不同表中的存放位置。

(2)確定單一的父子關(guān)系結(jié)構(gòu)

所謂確定單一的父系關(guān)系結(jié)構(gòu)就是要在所建立的各種表中消除多對(duì)多(以下用M:N來(lái)表示)的現(xiàn)象,即設(shè)法使得所有表中記錄之間的關(guān)系呈樹(shù)狀結(jié)構(gòu)(只能由一個(gè)主干發(fā)出若干條分支,而不能有若干條主干交錯(cuò)發(fā)出若干條分支狀況)。所謂的“父系”就是指表的上一級(jí)關(guān)系表。消除多對(duì)多關(guān)系可以借助于E-R圖的方法來(lái)解決,也可以在系統(tǒng)分析時(shí)予以注意,避免這種情況的發(fā)生。

消除這種M:N情況的辦法也很簡(jiǎn)單,只需在二表之間增加一個(gè)表,則原來(lái)M:N的關(guān)系就改成了M:1,1:N的關(guān)系了。

確定數(shù)據(jù)資源的安全保密屬性:

一般DBMS都提供給我們自己定義數(shù)據(jù)安全保密性的功能。系統(tǒng)所提供的安全保密功能一般有8個(gè)等級(jí)(0-7級(jí)),4種不同方式(只讀、只寫、刪除、修改),而且允許用戶利用這8個(gè)等級(jí)的4種方式對(duì)每一個(gè)表自由地進(jìn)行定義。

定義安全保密性的方法一般有如下幾種:

a.原則上所有文件都定義為4級(jí),個(gè)別優(yōu)先級(jí)特別高的辦公室(終端或微機(jī)的入網(wǎng)賬號(hào))可定義高于4級(jí)的級(jí)別,反之則定義為低于4的級(jí)別。

b.統(tǒng)計(jì)文件(表)和數(shù)據(jù)錄入文件一般只對(duì)本工作站定義為只寫方式,對(duì)其它工作站則定義為只讀方式。

c.財(cái)務(wù)等保密文件一般只對(duì)中工作站(如財(cái)務(wù)科等)定義為可寫、可改、可刪除方式,對(duì)其它工作站則定義為只讀方式,而且不是每個(gè)人都能讀,只有級(jí)別相同和高級(jí)別者才能讀。

2.1.2數(shù)據(jù)庫(kù)設(shè)計(jì)范式分析

建立起一個(gè)良好的數(shù)據(jù)指標(biāo)體系,是建立數(shù)據(jù)結(jié)構(gòu)和數(shù)據(jù)庫(kù)的最重要的一環(huán)。一個(gè)良好的數(shù)據(jù)指標(biāo)體系是建立DB的必要條件,但不是充分條件。我們完全可以認(rèn)為所建指標(biāo)體系中的一個(gè)指標(biāo)類就是關(guān)系數(shù)據(jù)庫(kù)中的一個(gè)基本表,而這個(gè)指標(biāo)類下面的一個(gè)個(gè)具體指標(biāo)就是這個(gè)基本表中的一個(gè)字段。但如果直接按照這種方式建庫(kù)顯然還不能算最佳。對(duì)于指標(biāo)體系中數(shù)據(jù)的結(jié)構(gòu)在建庫(kù)前還必須進(jìn)行規(guī)范化的重新組織。

a.數(shù)據(jù)組織的規(guī)范化形式

在數(shù)據(jù)的規(guī)范化表達(dá)中,一般將一組相互關(guān)聯(lián)的數(shù)據(jù)稱為一個(gè)關(guān)系(relation),而在這個(gè)關(guān)系下的每個(gè)數(shù)據(jù)指標(biāo)項(xiàng)則被稱為數(shù)據(jù)元素(dataelement),這種關(guān)系落實(shí)到具體數(shù)據(jù)庫(kù)上就是基本表,而數(shù)據(jù)元素就是基本表中的一個(gè)字段(field)。規(guī)范化表達(dá)還規(guī)定在每一個(gè)基本表中必須定義一個(gè)數(shù)據(jù)元素為關(guān)鍵字(key),它可以唯一地標(biāo)識(shí)出該表中其它相關(guān)的數(shù)據(jù)元素。在規(guī)范化理論中表是二維的,它有如下四個(gè)性質(zhì):

l在表中的任意一列上,數(shù)據(jù)項(xiàng)應(yīng)屬于同一個(gè)屬性(如圖中每一列都存放著不同合同記錄的同一屬性數(shù)據(jù))。

l表中所有行都是不相同的,不允許有重復(fù)組項(xiàng)出現(xiàn)(如圖中每一行都是一個(gè)不同的合同記錄)。

l在表中,行的順序無(wú)關(guān)緊要(如圖中每行存的都是合同記錄,至于先放哪一個(gè)合同都沒(méi)關(guān)系)。

l在表中,列的順序無(wú)關(guān)緊要,但不能重復(fù)(如圖中合同號(hào)和合同名誰(shuí)先誰(shuí)后都沒(méi)關(guān)系,但二者不可重復(fù)或同名)。

在對(duì)表的形式進(jìn)行了規(guī)范化定義后,數(shù)據(jù)結(jié)構(gòu)還有五種規(guī)范化定義,定名為規(guī)范化模式,稱為范式。在這五種范式中,一般只用前三種,對(duì)于常用系統(tǒng)就足夠了。而且這五種范式是“向上兼容”的,即滿足第五范式的數(shù)據(jù)結(jié)構(gòu)自動(dòng)滿足一、二、三、四范式,滿足第四范式的數(shù)據(jù)結(jié)構(gòu)自動(dòng)滿足第一、二、三范式,……,依此類推。

第一范式(firstnormalform,簡(jiǎn)稱1stNF)就是指在同一表中沒(méi)有重復(fù)項(xiàng)出現(xiàn),如果有則應(yīng)將重復(fù)項(xiàng)去掉。這個(gè)去掉重復(fù)項(xiàng)的過(guò)程就稱之為規(guī)范化處理。在本文所討論的開(kāi)發(fā)方法里,1stNF實(shí)際上是沒(méi)有什么意義的。因?yàn)槲覀儼匆?guī)范化建立的指標(biāo)體系和表的過(guò)程都自動(dòng)保證了所有表都滿足1stNF。

第二范式(secondnormalform,簡(jiǎn)稱2ndNF)是指每個(gè)表必須有一個(gè)(而且僅一個(gè))數(shù)據(jù)元素為主關(guān)鍵字(primarykey),其它數(shù)據(jù)元素與主關(guān)鍵字一一對(duì)應(yīng)。例如,在圖l9.7中如果我們將合同號(hào)定義為主關(guān)鍵字(其它數(shù)據(jù)元素中的記錄數(shù)據(jù)都有可能重名,故不能作為主關(guān)鍵字),故只要知道了一個(gè)合同記錄的合同號(hào),就可以唯一地在同一行中找到該合同的任何一項(xiàng)具體信息。通常我們稱這種關(guān)系為函數(shù)依賴(functionaldepEndence)關(guān)系。即表中其它數(shù)據(jù)元素都依賴于主關(guān)鍵字,或稱該數(shù)據(jù)元素唯一地被主關(guān)鍵字所標(biāo)識(shí)。

第三范式(thirdnormalform,簡(jiǎn)稱3rdNF)就是指表中的所有數(shù)據(jù)元素不但要能夠唯一地被主關(guān)鍵字所標(biāo)識(shí),而且它們之間還必須相互獨(dú)立,不存在其它的函數(shù)關(guān)系。也就是說(shuō)對(duì)于一個(gè)滿足了2ndNF的數(shù)據(jù)結(jié)構(gòu)來(lái)說(shuō),表中有可能存在某些數(shù)據(jù)元素依賴于其它非關(guān)鍵宇數(shù)據(jù)元素的現(xiàn)象,必須加以消除。

為防止數(shù)據(jù)庫(kù)出現(xiàn)更新異常、插入異常、刪除異常、數(shù)據(jù)冗余太大等現(xiàn)象,關(guān)系型數(shù)據(jù)庫(kù)要盡量按關(guān)系規(guī)范化要求進(jìn)行數(shù)據(jù)庫(kù)設(shè)計(jì)。

§2.2SQL語(yǔ)言介紹

2.2.1SQL基礎(chǔ)

SQL(StructuredQueryLanguage,結(jié)構(gòu)查詢語(yǔ)言)是一個(gè)功能強(qiáng)大的數(shù)據(jù)庫(kù)語(yǔ)言。SQL通常使用于數(shù)據(jù)庫(kù)的通訊。ANSI(美國(guó)國(guó)家標(biāo)準(zhǔn)學(xué)會(huì))聲稱,SQL是關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)的標(biāo)準(zhǔn)語(yǔ)言。SQL語(yǔ)句通常用于完成一些數(shù)據(jù)庫(kù)的操作任務(wù),比如在數(shù)據(jù)庫(kù)中更新數(shù)據(jù),或者從數(shù)據(jù)庫(kù)中檢索數(shù)據(jù)。使用SQL的常見(jiàn)關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)有:Oracle、Sybase、MicrosoftSQLServer、Access、Ingres等等。雖然絕大多數(shù)的數(shù)據(jù)庫(kù)系統(tǒng)使用SQL,但是它們同樣有它們自立另外的專有擴(kuò)展功能用于它們的系統(tǒng)。但是,標(biāo)準(zhǔn)的SQL命令,比如"Select"、"Insert"、"Update"、"Delete"、"Create"和"Drop"常常被用于完成絕大多數(shù)數(shù)據(jù)庫(kù)的操作。MSSQLServer就是用的Transact-SQL。

SQL語(yǔ)言有著非常突出的優(yōu)點(diǎn),主要是:

n非過(guò)程化語(yǔ)言

n統(tǒng)一的語(yǔ)言

n是所有關(guān)系數(shù)據(jù)庫(kù)的公共語(yǔ)言

非過(guò)程化語(yǔ)言:SQL是一個(gè)非過(guò)程化的語(yǔ)言,因?yàn)樗淮翁幚硪粋€(gè)記錄,對(duì)數(shù)據(jù)提供自動(dòng)導(dǎo)航。SQL允許用戶在高層的數(shù)據(jù)結(jié)構(gòu)上工作,而不對(duì)單個(gè)記錄進(jìn)行操作,可操作記錄集,所有SQL語(yǔ)句接受集合作為輸入,返回集合作為輸出。SQL的集合特性允許一條SQL語(yǔ)句的結(jié)果作為另一條SQL語(yǔ)句的輸入。

SQL不要求用戶指定對(duì)數(shù)據(jù)的存放方法,這種特性使用戶更易集中精力于要得到的結(jié)果;所有SQL語(yǔ)句使用查詢優(yōu)化器,它是RDBMS的一部分,由它決定對(duì)指定數(shù)據(jù)存取的最快速度的手段,查詢優(yōu)化器知道存在什么索引,在哪兒使用索引合適,而用戶則從不需要知道表是否有索引、有什么類型的索引。

統(tǒng)一的語(yǔ)言:SQL可用于所有用戶的DB活動(dòng)模型,包括系統(tǒng)管理員、數(shù)據(jù)庫(kù)管理員、應(yīng)用程序員、決策支持系統(tǒng)人員及許多其它類型的終端用戶。

SQL為許多任務(wù)提供了命令,其中包括:

n查詢數(shù)據(jù)

n在表中插入、修改和刪除記錄

n建立、修改和刪除數(shù)據(jù)對(duì)象

n控制對(duì)數(shù)據(jù)和數(shù)據(jù)對(duì)象的存取

n保證數(shù)據(jù)庫(kù)一致性和完整性

以前的數(shù)據(jù)庫(kù)管理系統(tǒng)為上述各類操作提供單獨(dú)的語(yǔ)言,而SQL將全部任務(wù)統(tǒng)一在一種語(yǔ)言中。

所有關(guān)系數(shù)據(jù)庫(kù)的公共語(yǔ)言:由于所有主要的關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)都支持SQL語(yǔ)言,用戶可將使用SQL的技能從一個(gè)RDBMS(關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng))轉(zhuǎn)到另一個(gè),所有用SQL編寫的程序都是可以移植的。

2.2.2SQL語(yǔ)句

SQL功能強(qiáng)大,是一種完備的數(shù)據(jù)處理語(yǔ)言,不僅用于數(shù)據(jù)庫(kù)查詢,而且用于數(shù)據(jù)庫(kù)中的數(shù)據(jù)修改和更新,概括起來(lái),它可以分成以下幾組:

DML(DataManipulationLanguage,數(shù)據(jù)操作語(yǔ)言):用于檢索或者修改數(shù)據(jù);

DDL(DataDefinitionLanguage,數(shù)據(jù)定義語(yǔ)言):用于定義數(shù)據(jù)的結(jié)構(gòu),比如創(chuàng)建、修改或者刪除數(shù)據(jù)庫(kù)對(duì)象;

DCL(DataControlLanguage,數(shù)據(jù)控制語(yǔ)言):用于定義數(shù)據(jù)庫(kù)用戶的權(quán)限。

DML組可以細(xì)分為以下的幾個(gè)語(yǔ)句:

SELECT:用于檢索數(shù)據(jù);

INSERT:用于增加數(shù)據(jù)到數(shù)據(jù)庫(kù);

UPDATE:用于從數(shù)據(jù)庫(kù)中修改現(xiàn)存的數(shù)據(jù);

DELETE:用于從數(shù)據(jù)庫(kù)中刪除數(shù)據(jù)。

DDL語(yǔ)句可以用于創(chuàng)建用戶和重建數(shù)據(jù)庫(kù)對(duì)象。下面是DDL命令:

CREATETABLE,ALTERTABLE,DROPTABLE,CREATEINDEX,DROPINDEX

下面是一個(gè)簡(jiǎn)單SQL語(yǔ)句的例子:

我們使用SQL語(yǔ)句來(lái)從Book中檢索‘借書證號(hào)’為‘000001’的借閱者姓名:

SELECT姓名FROMBookWHERE借書證號(hào)=‘000001’

2.2.2.1DDL與DML

數(shù)據(jù)定義語(yǔ)言DDL:它是用來(lái)創(chuàng)建和修改數(shù)據(jù)庫(kù)結(jié)構(gòu)的一種語(yǔ)句,包括Create、Alter和Drop語(yǔ)句。

數(shù)據(jù)操作語(yǔ)言DML:包括數(shù)據(jù)查詢與數(shù)據(jù)更新。數(shù)據(jù)查詢主要是由Select語(yǔ)句完成,這一點(diǎn)不再贅述。而數(shù)據(jù)更新所造成的風(fēng)險(xiǎn)大大超過(guò)數(shù)據(jù)查詢。數(shù)據(jù)庫(kù)管理系統(tǒng)必須在更改期內(nèi)保護(hù)所存儲(chǔ)的數(shù)據(jù)的一致性,確保有效的數(shù)據(jù)進(jìn)入數(shù)據(jù)庫(kù),數(shù)據(jù)庫(kù)必須保持一致性,DBMS還必須協(xié)調(diào)多用戶的并行更新,以確保用戶和它們的更改不至于影響其它用戶的作業(yè)。

用于修改數(shù)據(jù)庫(kù)內(nèi)容的SQL語(yǔ)句主要有以下三個(gè):

(1)Insert,向一個(gè)表中加入新的數(shù)據(jù)行

(2)Delete,從一個(gè)表中刪除數(shù)據(jù)行

(3)Update,更改數(shù)據(jù)庫(kù)中已經(jīng)存在的數(shù)據(jù)

Insert標(biāo)準(zhǔn)語(yǔ)法:

INSERTINTOtable_name(col1,col2...)VALUES(value1,value2...)

下例要將借書證號(hào)為‘000001’作為一個(gè)新的借書情況加入借書情況表OWNER中

InsertInto

owner(借書證號(hào),圖書編號(hào),借書日期)

values(‘000001’,‘00000001’,‘2002-9-12’)

Insert語(yǔ)句還可以將多行數(shù)據(jù)添加到目標(biāo)表中去,在這種形式的Insert語(yǔ)句中,新行的數(shù)據(jù)值不是在語(yǔ)句正文中明確地指定的,而是語(yǔ)句中指定的一個(gè)數(shù)據(jù)庫(kù)查詢。添加的值來(lái)自數(shù)據(jù)庫(kù)自身的行,在某些特定的狀態(tài)下,這是非常有用的。多行Insert語(yǔ)句為拷貝數(shù)據(jù)提供了一種緊湊而高效的方法,但我在自已做的圖書管理系統(tǒng)中沒(méi)有使用這種方法,我在系統(tǒng)中是使用循環(huán)依照上面的用法來(lái)完成多個(gè)記錄的插入。

Update語(yǔ)句用于更新單表中選定行的一列或多列的值。要更新的目標(biāo)表在語(yǔ)句中定義,Set子句則指定要更新哪些列并計(jì)算它們的值。Update語(yǔ)句總是包含Where語(yǔ)句,而且Update語(yǔ)句比較危險(xiǎn),所以您必須明確地認(rèn)識(shí)到Where語(yǔ)句的重要性,Where語(yǔ)句被用來(lái)指定需要更新的行。

標(biāo)準(zhǔn)語(yǔ)法:

UPDATEtable_name

SETcolumnname1=value1

[,columname2=value2]...

WHEREsearch_condition

Delete語(yǔ)句標(biāo)準(zhǔn)語(yǔ)法:

DELETEFROMtablenameWHEREcondition

2.2.2.2復(fù)雜操作實(shí)現(xiàn)

在信息管理系統(tǒng)中,我們往往會(huì)遇到歸類、匯總、映射、索引、子查詢等復(fù)雜操作,相應(yīng)的支持與實(shí)現(xiàn)如下:

uGROUPBY方法

GROUPBY子句語(yǔ)法為:

SELECTcolumn1,SUM(column2)

FROM"list-of-tables"

GROUPBY"column-list";

這個(gè)GROUPBY子句將集中所有的行在一起,它包含了指定列的數(shù)據(jù)以及允許合計(jì)函數(shù)來(lái)計(jì)算一個(gè)或者多個(gè)列。

在本人的系統(tǒng)中在顯示數(shù)據(jù)時(shí)用到了此語(yǔ)句來(lái)對(duì)查詢所得的內(nèi)容排序然后再顯示。

u組合條件和布爾運(yùn)算符

以下的SQL語(yǔ)句中就含有組合條件:

SELECTcolumn1,SUM(column2)

FROM"list-of-tables"

WHERE"condition1"AND"condition2";

下面是一個(gè)示例:

SELECT身份描述

FROMID,user

WHEREID.身份編號(hào)=USER.身份編號(hào)anduser.借書證號(hào)=’000001’;

這條SQL語(yǔ)句是從user、id表中查找借閱證號(hào)為000001的借閱者的身份描述,第三條語(yǔ)句中如果其中有一個(gè)條件為假,那么就什么都沒(méi)有顯示。

uUNION子句

有些時(shí)候,需要一起瀏覽多個(gè)查詢的結(jié)果、組合它們的輸出,我們可以使用UNION關(guān)鍵字。

第三章應(yīng)用系統(tǒng)開(kāi)發(fā)工具

§3.1Delphi6.0VCL組件的體系結(jié)構(gòu)

Delphi類可以粗略地分成兩部分:一部分是組件類,這些組件類通常以某種方式出現(xiàn)在組件面板上,當(dāng)用戶從組件面板上點(diǎn)取一個(gè)類的圖標(biāo)后,在程序中就自動(dòng)生成了該類的對(duì)象(非可視組件除外);另一部分是功能類,這此功能類的對(duì)象通常出現(xiàn)在程序代碼中,起著不可代替的作用,但是這些功能類在組件面板上是找不到的。在Delphi中,每一個(gè)類的祖先都是Tobject類,整個(gè)類的層次結(jié)構(gòu)就像一棵倒掛的樹(shù),在最頂層的樹(shù)根即為Tobject類。這樣,按照面向?qū)ο缶幊痰幕舅枷耄褪沟糜脩艨捎肨object類這個(gè)類型代替任何其它類的數(shù)據(jù)類型。實(shí)際上在Delphi的類庫(kù)中,Tobject類派生出了為數(shù)相當(dāng)眾多的子類,它們形成了一個(gè)龐大的體系,通常情況下,如果不自行開(kāi)發(fā)組件,就不必了解整個(gè)類的體系結(jié)構(gòu),只用到類層次樹(shù)的葉結(jié)點(diǎn)就足夠了。

這一小節(jié)簡(jiǎn)略介紹一下Delphi6.0中VCL(可視化組件庫(kù))組件的體系結(jié)構(gòu)。凡是做過(guò)程序開(kāi)發(fā)的人都知道從來(lái)沒(méi)有單純的數(shù)據(jù)應(yīng)用程序,也就是說(shuō),數(shù)據(jù)庫(kù)應(yīng)用程序必須和用戶界面(可以是圖形界面,也可以是命令接口)元素相結(jié)合,只講界面或只講數(shù)據(jù)庫(kù)本身都構(gòu)不成數(shù)據(jù)庫(kù)應(yīng)用程序,因而用Delphi6.0開(kāi)發(fā)數(shù)據(jù)庫(kù)應(yīng)用程序就隱含著界面開(kāi)發(fā)。Delphi6中的VCL組件可用圖3-1來(lái)說(shuō)明。

組件在Delphi程序的開(kāi)發(fā)中是最顯眼的角色。大家知道,在編寫程序時(shí)一般都開(kāi)始于在組件面板上選擇組件并定義組件間的相互作用。但也有一些組件不在組件面板上,例如Tform和Tapplication(典型的非可視組件)。組件是Tcomponents派生出來(lái)的子類,可以流的形式存放在DFM文件中,具有事件和Publish屬性。

窗口組件類是窗口化的可視化組件類,在Delphi的類庫(kù)中占有最大的份額。在實(shí)際編程中,窗口組件類的對(duì)象都有句柄,可以接受輸入焦點(diǎn)和包含其它組件。

圖形組件與窗口組件并列,是另一大類組件。圖形組件不是基于窗口的,因而不能有窗口句柄,不能接受輸入焦點(diǎn)和包含其它組件。從圖8-43中可以看出,圖形組件的基類是TgraphicControl,在實(shí)際編程中,它們必須寄生于它們的宿主——窗口組件類的對(duì)象,由它們的擁有者負(fù)責(zé)其顯示,而且它們還能觸發(fā)一些和鼠標(biāo)活動(dòng)相關(guān)的事件。圖形控件最典型的例子是Tlabel和TspeedButton。由此可以看出圖形組件的功能很弱,圖形組件的用處何在呢?其實(shí)使用圖形組件的最大好處在于節(jié)省資源,正是因?yàn)樗鼈兊墓δ茌^弱,所以使用的系統(tǒng)資源就要少。在一個(gè)應(yīng)用程序中,如果能在不影響其功能的前提下合理大量地使用圖形組件,將會(huì)大減少程序?qū)ο到y(tǒng)資源的消耗。

非可視組件是與可視組件相并列的另一類組件,非可視組件在程序運(yùn)行中是不可見(jiàn)的(除各種對(duì)話框組件之外,事實(shí)上有人認(rèn)為對(duì)話框組件不能歸入非可視組件,應(yīng)該是另一種介于可視與非可視之間的組件)。

最后要說(shuō)明一下,常說(shuō)的控件實(shí)際上是一種組件。也就是說(shuō)組件這個(gè)概念要大于控件,控件在內(nèi)涵上包含于組件中。控件由Windows系列操作系統(tǒng)提出并使用,而組件是Borland和其它廠商在對(duì)Windows控件做了必要的擴(kuò)展之后提出來(lái)的概念,它們是在不同時(shí)期由不同的廠商提出的概念。

§3.2數(shù)據(jù)庫(kù)組件介紹

用Delphi6開(kāi)發(fā)數(shù)據(jù)庫(kù)應(yīng)用,重點(diǎn)是和各種數(shù)據(jù)庫(kù)組件打交道,能和數(shù)據(jù)庫(kù)掛鉤的組件對(duì)象有5種,它們是:Session(數(shù)據(jù)庫(kù)會(huì)話)、Database(數(shù)據(jù)庫(kù))、Dataset(數(shù)據(jù)集)、DataSource(數(shù)據(jù)源)、Datacontrol(數(shù)據(jù)控制組件,也叫data-controls即數(shù)據(jù)感知組件)。其中前面4種統(tǒng)稱為數(shù)據(jù)訪問(wèn)(DataAccess)組件。這些組件的相互關(guān)系如圖3-2所示。

ADO組件Delphi6.0包含了可以用來(lái)訪問(wèn)Microsoft公司的ActiveXDataObjects(ADO)格式數(shù)據(jù)庫(kù)的組件。ADO是Micrsoft公司關(guān)于各種類型數(shù)據(jù)的高等界面,后來(lái)逐漸演變成滿足所有數(shù)據(jù)訪問(wèn)需要的完整解決辦法。ADO的對(duì)象模型是所有數(shù)據(jù)訪問(wèn)接口對(duì)象模型中最簡(jiǎn)單的一種。Microsoft公司用來(lái)訪問(wèn)ADO數(shù)據(jù)的應(yīng)用程序界面技術(shù)是OLEDB。OLEDB是一種底層編程接口,用來(lái)訪問(wèn)許多不同類型的數(shù)據(jù)源,其中包括消息、文件系統(tǒng)以及其他一些非傳統(tǒng)的數(shù)據(jù)源。OLEDB是一個(gè)由ComponentObjectModel(COM)接口組成的集合,用來(lái)隱藏創(chuàng)建數(shù)據(jù)訪問(wèn)服務(wù)過(guò)程中的細(xì)節(jié)。OLEDB提供了訪問(wèn)任何數(shù)據(jù)資源的方法,包括相互關(guān)聯(lián)的數(shù)據(jù)庫(kù)和相互不關(guān)聯(lián)的數(shù)據(jù)庫(kù)、Email和文件系統(tǒng)、文本和圖形以及用戶定義的數(shù)據(jù)對(duì)象。

Delphi的ADO組件無(wú)需依靠BDE而是使用ADO技術(shù),提供了可以通過(guò)數(shù)據(jù)控制組件訪問(wèn)數(shù)據(jù)的新方法。唯一的要求是在使用ADO組件時(shí)必須運(yùn)行ADO/OLE-DB。ADO組件的使用使得DELPHI在訪問(wèn)數(shù)據(jù)的類型和采用的技術(shù)方面都有了很大的突破。

數(shù)據(jù)模塊設(shè)計(jì)窗口數(shù)據(jù)模塊設(shè)計(jì)窗口是用來(lái)設(shè)計(jì)和維護(hù)數(shù)據(jù)模塊的。數(shù)據(jù)模塊設(shè)計(jì)窗口中包含了所有以.DTI作為文件擴(kuò)展名的DataDiagram文件的信息。DTI文件在編譯時(shí)不起任何作用。

§3.3SQL語(yǔ)言在Delphi中的應(yīng)用

在Delphi中使用SQL語(yǔ)言非常方便,一般來(lái)說(shuō),都是通過(guò)Tquery或TADOquery組件來(lái)使用SQL語(yǔ)言的。可以在Tquery或TADOquery組件的SQL屬性中設(shè)置SQL語(yǔ)句。設(shè)計(jì)程序時(shí),在該組件的屬性對(duì)話框中選擇SQL屬性,單擊帶省略號(hào)的按鈕,就可以打開(kāi)StringListEditor對(duì)話框,然后我們就可以在對(duì)話框中添加SQL語(yǔ)句。還可以使用Delphi的SQLBuilder來(lái)自動(dòng)生成SQL語(yǔ)句,這樣可以避免手工編寫SQL而可能造成的語(yǔ)法錯(cuò)誤。

靜態(tài)SQL語(yǔ)句在程序設(shè)計(jì)時(shí)便已固定下來(lái),它不包含任何參數(shù)和變量。

動(dòng)態(tài)SQL語(yǔ)句,也被稱作參數(shù)化的語(yǔ)句,在其中間包含著表示字段名或表名的參數(shù),例如下面的語(yǔ)句是一條動(dòng)態(tài)SQL語(yǔ)句:

Select*FromBookWhere圖書編號(hào)=:bookCode;

其中的變量bookCode便是一個(gè)參數(shù)變量,它由一個(gè)冒號(hào)引導(dǎo),在程序運(yùn)行過(guò)程中,必須要為該參數(shù)賦值,該條SQL語(yǔ)句才能正確執(zhí)行,每次運(yùn)行應(yīng)用程序時(shí)可以為該參數(shù)變量賦予不同的值。為參數(shù)賦值有三種方法:

①根據(jù)參數(shù)在SQL語(yǔ)句中出現(xiàn)的順序,設(shè)置TADOQuery組件的parameters屬性值為參數(shù)賦值。

②直接根據(jù)SQL語(yǔ)句中各參數(shù)的名字,調(diào)用ParamByName方法來(lái)為各參數(shù)賦值。

③將TADOQuery組件的DataSource屬性設(shè)置為另一個(gè)數(shù)據(jù)源,這樣將另一個(gè)數(shù)據(jù)源中與當(dāng)前TADOQuery組件的SQL語(yǔ)句中的參數(shù)名相匹配的字段值賦給其對(duì)應(yīng)的參數(shù)。利用這種方法也能實(shí)現(xiàn)所謂的連接查詢,創(chuàng)建主要—明細(xì)型數(shù)據(jù)庫(kù)應(yīng)用。

在使用動(dòng)態(tài)SQL語(yǔ)句編程時(shí),常常用到一個(gè)很重要的方法Prepare,調(diào)用Prepare方法之后,Delphi會(huì)將帶參數(shù)的SQL語(yǔ)句傳送給與其對(duì)應(yīng)的數(shù)據(jù)庫(kù)引擎,對(duì)動(dòng)態(tài)SQL語(yǔ)句進(jìn)行語(yǔ)法分析和優(yōu)化。雖然在用動(dòng)態(tài)SQL語(yǔ)句編程時(shí),調(diào)用Prepare方法并不是必須的,但是調(diào)用Prepare方法后,會(huì)極大地提高動(dòng)態(tài)SQL語(yǔ)句的執(zhí)行性能,特別是當(dāng)要反復(fù)多次執(zhí)行同一條動(dòng)態(tài)SQL語(yǔ)句時(shí),其優(yōu)越性會(huì)更加明顯。如果在應(yīng)用程序中執(zhí)行一條SQL語(yǔ)句之前并沒(méi)有顯式地調(diào)用Prepare方法,每次在執(zhí)行SQL語(yǔ)句時(shí),Delphi會(huì)隱含地調(diào)用Prepare方法以準(zhǔn)備這個(gè)查詢。

TadoQuery部件還有一個(gè)Prepare屬性,這是一個(gè)布爾型屬性,當(dāng)其屬性值為True時(shí),表明該查詢已被準(zhǔn)備好了(SQL語(yǔ)句已被傳送到數(shù)據(jù)庫(kù)引擎中),當(dāng)我們使用參數(shù)編輯器ParametersEditor來(lái)為動(dòng)態(tài)SQL語(yǔ)句中的參數(shù)賦值時(shí),當(dāng)設(shè)置完相應(yīng)的參數(shù)值并退出參數(shù)編輯器時(shí),Delphi會(huì)隱含地調(diào)用Prepare方法以準(zhǔn)備好查詢。

當(dāng)SQL語(yǔ)句執(zhí)行完之后,要想準(zhǔn)備下一個(gè)查詢,首先必須調(diào)用Close方法,然后才能調(diào)用Prepare方法準(zhǔn)備下一個(gè)查詢。一般來(lái)說(shuō),在一個(gè)應(yīng)用程序中應(yīng)該調(diào)用一次Prepare方法,常常在窗體的OnCreate事件處理過(guò)程中調(diào)用Prepare方法,然后用上述介紹的方法為參數(shù)賦值,最后調(diào)用Open方法或ExecSQL方法執(zhí)行SQL語(yǔ)句,以完成查詢。

當(dāng)然在調(diào)用Prepare方法準(zhǔn)備好一個(gè)查詢時(shí),會(huì)消耗一些數(shù)據(jù)庫(kù)資源,因而每當(dāng)一個(gè)查詢執(zhí)行完畢之后,要養(yǎng)成調(diào)用UnPrepare方法以撤消查詢的好習(xí)慣。在運(yùn)行程序過(guò)程中,通過(guò)程序改變TQuery或TADOquery部件的SQL屬性值時(shí),Delphi會(huì)自動(dòng)地調(diào)用Close方法和UnPrepare方法,以撤消查詢。

在程序運(yùn)行過(guò)程中,要想設(shè)置Tquery或TADOquery部件的SQL屬性,必須首先調(diào)用Close方法,關(guān)閉TQuery或TADOquery部件,然后再調(diào)用Clear方法清除SQL屬性中現(xiàn)存的SQL命令語(yǔ)句,最后再調(diào)用Add方法為SQL屬性設(shè)置新的SQL命令語(yǔ)句。例如:

datamodule4.adoquery2.close;

datamodule4.adoquery2.sql.clear;

datamodule4.adoquery2.sql.add(''''SELECT借書證號(hào),密碼FROM[user]WHERE(借書證號(hào)=:tt)'''');

datamodule4.adoquery2.parameters[0].value:=username;

datamodule4.adoquery2.open;

在為TQuery或TADOquery部件設(shè)置SQL屬性時(shí)調(diào)用Close方法總是很安全的,如果TQuery或TADOquery部件已經(jīng)被關(guān)閉了,調(diào)用Close方法時(shí)不會(huì)產(chǎn)生任何影響。在應(yīng)用程序中為SQL屬性設(shè)置新的SQL命令語(yǔ)句時(shí),必須要調(diào)用Clear方法以清除SQL屬性中現(xiàn)存的SQL命令語(yǔ)句,如果不調(diào)用Clear方法,便調(diào)用Add方法向SQL屬性中設(shè)置SQL命令語(yǔ)句,那么新設(shè)置的SQL命令語(yǔ)句會(huì)追加在現(xiàn)存SQL命令語(yǔ)句后面,在程序運(yùn)行時(shí)常常會(huì)出現(xiàn)出乎意料的查詢結(jié)果甚至程序無(wú)法運(yùn)行下去。

在這里要特別注意的,一般情況下TQuery或TADOquery部件的SQL屬性只能包含一條完整的SQL語(yǔ)句,它不允許被設(shè)置成多條SQL語(yǔ)句。當(dāng)然有些數(shù)據(jù)庫(kù)服務(wù)器也支持在TQuery或TADOquery部件的SQL屬性中設(shè)置多條SQL語(yǔ)句,只要數(shù)據(jù)庫(kù)服務(wù)器允許這樣,我們?cè)诰幊虝r(shí)可以為SQL屬性設(shè)置多條SQL語(yǔ)句。

在為TQuery或TADOquery部件設(shè)置完SQL屬性的屬性值之后,也即編寫好適當(dāng)?shù)腟QL程序之后,可以有多種方式來(lái)執(zhí)行SQL程序。

在設(shè)計(jì)過(guò)程中,設(shè)置完TQuery或TADOquery部件的SQL屬性之后將其Active屬性的值置為True,這樣便可以執(zhí)行SQL屬性中的SQL程序,如果應(yīng)用中有與TQuery或TADOquery部件相連的數(shù)據(jù)瀏覽部件(如TDDGridTDBEdit等)那么在這些數(shù)據(jù)瀏覽部件中會(huì)顯示SQL程序的執(zhí)行結(jié)果。

在應(yīng)用程序運(yùn)行過(guò)程中,通過(guò)程序調(diào)用TQuery或TADOquery組件的Open方法或ExecSQL方法可以執(zhí)行其SQL屬性中的SQL程序。Open方法和ExecSQL方法是不一樣的。Open方法只能用來(lái)執(zhí)行SQL語(yǔ)言的查詢語(yǔ)句(Select命令),并返回一個(gè)查詢結(jié)果集,而ExecSQL方法還可以用來(lái)執(zhí)行其它常用的SQL語(yǔ)句(如INSERT,UPDATE,DELETE等命令),例如:

Query1.Open(這樣會(huì)返回一個(gè)查詢結(jié)果集)

如果調(diào)用Open方法,而沒(méi)有查詢結(jié)果時(shí),會(huì)出錯(cuò)。此時(shí)應(yīng)該調(diào)用ExecSQL方法來(lái)代替Open方法。如:

Query1.ExecSQL(沒(méi)有返回結(jié)果)

當(dāng)然在設(shè)計(jì)應(yīng)用程序時(shí),程序設(shè)計(jì)人員是無(wú)法確定TQuery或TADOquery組件中的SQL語(yǔ)句是否會(huì)返回一個(gè)查詢結(jié)果的。對(duì)于這種情況應(yīng)當(dāng)用Try…Except模塊來(lái)設(shè)計(jì)程序。在Try部分調(diào)用Open方法,而在Except部分調(diào)用ExceSQL方法,這樣才能保證程序的正確運(yùn)行。

例如:

Try

Query1.Open

Except

Query1.ExecSQL

End

通過(guò)Tquery或TADOquery組件可以獲得兩種類型的數(shù)據(jù):

u“活動(dòng)”的數(shù)據(jù)

這種數(shù)據(jù)就跟通過(guò)TTable部件獲得的數(shù)據(jù)一樣,用戶可以通過(guò)數(shù)據(jù)瀏覽部件來(lái)編輯修改這些數(shù)據(jù),并且當(dāng)調(diào)用Post方法或當(dāng)焦點(diǎn)離開(kāi)當(dāng)前的數(shù)據(jù)瀏覽部件時(shí),用戶對(duì)數(shù)據(jù)的修改自動(dòng)地被寫回到數(shù)據(jù)庫(kù)中。

u非活動(dòng)的數(shù)據(jù)(只讀數(shù)據(jù))

用戶通過(guò)數(shù)據(jù)瀏覽部件是不能修改其中的數(shù)據(jù)。在缺省情況下,通過(guò)TQuery部件獲得的查詢結(jié)果數(shù)據(jù)是只讀數(shù)據(jù),要想獲得“活動(dòng)”的數(shù)據(jù),在應(yīng)用程序中必須要設(shè)置Tquery或TADOquery組件的RequestLive屬性值為True,然而并不是在任何情況下(通過(guò)設(shè)置RequestLive的屬值True)都可以獲得“活動(dòng)”的數(shù)據(jù)的,要想獲得“活動(dòng)”的數(shù)據(jù),除了將TQuery部件的RequestLive屬性設(shè)置為True外,相應(yīng)的SQL命令還要滿足以下條件。

本地SQL語(yǔ)句查詢情況下,要得到可更新的數(shù)據(jù)集,SQL語(yǔ)句的限制為:

n查詢只能涉及到一個(gè)單獨(dú)的表

nSQL語(yǔ)句中不能包含ORDERBY命令

nSQL語(yǔ)句中不能含聚集運(yùn)算符SUM或AVG

n在Select后的字段列表中不能有計(jì)算字段

n在Select語(yǔ)句WHERE部分只能包含字段值與常量的比較運(yùn)算,這些比較運(yùn)算符是:Like,>,<,>=,<=。各比較運(yùn)算之間可以有并和交運(yùn)算:AND和OR

當(dāng)通過(guò)SQL語(yǔ)句查詢數(shù)據(jù)庫(kù)服務(wù)器中的數(shù)據(jù)庫(kù)表:

n查詢只能涉及到一個(gè)單獨(dú)的表

nSQL語(yǔ)句中不能包含ORDERBY命令

nSQL語(yǔ)句中不能含聚集運(yùn)算符SUM或AVG運(yùn)算

另外,如果是查詢Sybase數(shù)據(jù)庫(kù)中的表,那么被查詢的表中只能有一個(gè)索引。

如果在應(yīng)用程序中要求TQuery或TADOquery組件返回一個(gè)“活動(dòng)”的查詢結(jié)果數(shù)據(jù)集,但是SQL命令語(yǔ)句不滿足上述約束條件時(shí),對(duì)于本地?cái)?shù)據(jù)庫(kù)的SQL查詢,BDE只能返回只讀的數(shù)據(jù)集。對(duì)于數(shù)據(jù)庫(kù)服務(wù)器中的SQL查詢,只能返回錯(cuò)誤的代碼。當(dāng)Tquery或TADOquery組件返回一個(gè)“活動(dòng)”的查詢結(jié)果數(shù)據(jù)集時(shí),它的CanModIfy屬性的值會(huì)被設(shè)置成True。

§3.4MSSQLServer簡(jiǎn)述

SQLServer是一個(gè)后臺(tái)數(shù)據(jù)庫(kù)管理系統(tǒng),它功能強(qiáng)大操作簡(jiǎn)便,日益為廣大數(shù)據(jù)庫(kù)用戶所喜愛(ài)。越來(lái)越多的開(kāi)發(fā)工具提供了與SQLServer的接口。SQLServer是一個(gè)關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng),它最初是由Microsoft、Sybase和Ashton-Tate三家公司共同開(kāi)發(fā)的。于1988年推出了第一個(gè)OS/2版本,在WindowsNT推出后,Microsoft與Sybase在SQLServer的開(kāi)發(fā)上就分道揚(yáng)鑣了,Microsoft將SQLServer移植到WindowsNT系統(tǒng)上,專注于開(kāi)發(fā)推廣SQLServer的WindowsNT版本。

SQLServer2000是Microsoft公司推出的SQLServer數(shù)據(jù)庫(kù)管理系統(tǒng)的最新版本,該版本繼承了SQLServer7.0版本的優(yōu)點(diǎn),同時(shí)又比它增加了許多更先進(jìn)的功能、具有使用方便、可伸縮性好與相關(guān)軟件集成程度高等優(yōu)點(diǎn)。可跨越從運(yùn)行MicrosoftWindows98的膝上型電腦到運(yùn)行MicrosoftWindows2000的大型多處理器的服務(wù)器等多種平臺(tái)使用。MSSQLServer不但可以應(yīng)用于大中型數(shù)據(jù)庫(kù)管理中,建立分布式關(guān)系數(shù)據(jù)庫(kù),并且也可以開(kāi)發(fā)桌面數(shù)據(jù)庫(kù)。事實(shí)上,SQLServer數(shù)據(jù)庫(kù)處理的基本結(jié)構(gòu),采取關(guān)系型數(shù)據(jù)庫(kù)模式,盡管如此,相信大家都可以輕易的發(fā)現(xiàn),在SQLServer的數(shù)據(jù)庫(kù)處理方式,則是使用面向?qū)ο蟮牟僮鞣绞脚c精神,也就是說(shuō),SQLServer的所有功能,都可以基于系統(tǒng)已經(jīng)建立好的一些對(duì)象來(lái)達(dá)成,是相當(dāng)OO(面向?qū)ο螅┑囊粋€(gè)系統(tǒng)結(jié)構(gòu)。

SQLServer企業(yè)管理器是SQLServer的主要管理工具,它提供了一個(gè)遵從MMC標(biāo)準(zhǔn)的用戶界面,使用戶得以:

·定義SQLServer實(shí)例組。

·將個(gè)別服務(wù)器注冊(cè)到組中。

·為每個(gè)已注冊(cè)的服務(wù)器配置所有SQLServer選項(xiàng)。

·在每個(gè)已注冊(cè)的服務(wù)器中創(chuàng)建并管理所有SQLServer數(shù)據(jù)庫(kù)、對(duì)象、登錄、用戶和權(quán)限。

·在每個(gè)已注冊(cè)的服務(wù)器上定義并執(zhí)行所有SQLServer管理任務(wù)。

·通過(guò)喚醒調(diào)用SQL查詢分析器,交互地設(shè)計(jì)并測(cè)試SQL語(yǔ)句、批處理和腳本。

·喚醒調(diào)用為SQLServer定義的各種向?qū)А?/p>

·

第三章圖書管理系統(tǒng)設(shè)計(jì)分析

§4.1應(yīng)用需求分析

圖書管理系統(tǒng)需要滿足來(lái)自三方面的需求,這三個(gè)方面分別是圖書借閱者、圖書館工作人員和圖書館管理人員。圖書借閱者的需求是查詢圖書館所存的圖書、個(gè)人借閱情況及個(gè)人信息的修改;圖書館工作人員對(duì)圖書借閱者的借閱及還書要求進(jìn)行操作,同時(shí)形成借書或還書報(bào)表給借閱者查看確認(rèn);圖書館管理人員的功能最為復(fù)雜,包括對(duì)工作人員、圖書借閱者、圖書進(jìn)行管理和維護(hù),及系統(tǒng)狀態(tài)的查看、維護(hù)并生成催還圖書報(bào)表。

圖書借閱者可直接查看圖書館圖書情況,如果圖書借閱者根據(jù)本人借書證號(hào)和密碼登錄系統(tǒng),還可以進(jìn)行本人借書情況的查詢和維護(hù)部分個(gè)人信息。一般情況下,圖書借閱者只應(yīng)該查詢和維護(hù)本人的借書情況和個(gè)人信息,若查詢和維護(hù)其他借閱者的借書情況和個(gè)人信息,就要知道其他圖書借閱者的借書證號(hào)和密碼。這些是很難得到的,特別是密碼,所以不但滿足了圖書借閱者的要求,還保護(hù)了圖書借閱者的個(gè)人隱私。

圖書館工作人員有修改圖書借閱者借書和還書記錄的權(quán)限,所以需對(duì)工作人員登陸本模塊進(jìn)行更多的考慮。在此模塊中,圖書館工作人員可以為圖書借閱者加入借書記錄或是還書記錄,并打印生成相應(yīng)的報(bào)表給用戶查看和確認(rèn)。

圖書館管理人員功能的信息量大,數(shù)據(jù)安全性和保密性要求最高。本功能實(shí)現(xiàn)對(duì)圖書信息、借閱者信息、總體借閱情況信息的管理和統(tǒng)計(jì)、工作人員和管理人員信息查看及維護(hù)。圖書館管理員可以瀏覽、查詢、添加、刪除、修改、統(tǒng)計(jì)圖書的基本信息;瀏覽、查詢、統(tǒng)計(jì)、添加、刪除和修改圖書借閱者的基本信息,瀏覽、查詢、統(tǒng)計(jì)圖書館的借閱信息,但不能添加、刪除和修改借閱信息,這部分功能應(yīng)該由圖書館工作人員執(zhí)行,但是,刪除某條圖書借閱者基本信息記錄時(shí),應(yīng)實(shí)現(xiàn)對(duì)該圖書借閱者借閱記錄的級(jí)聯(lián)刪除。并且還應(yīng)具有生成催還圖書報(bào)表,并打印輸出的功能。

在本系統(tǒng)中由于沒(méi)有打印機(jī)設(shè)備供試驗(yàn),所以預(yù)先把報(bào)表打印改成報(bào)表預(yù)覽。

設(shè)計(jì)不同用戶的操作權(quán)限和登陸方法

對(duì)所有用戶開(kāi)放的圖書查詢

借閱者維護(hù)借閱者個(gè)人部分信息

借閱者查看個(gè)人借閱情況信息

維護(hù)借閱者個(gè)人密碼

根據(jù)借閱情況對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作并生成報(bào)表

根據(jù)還書情況對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作并生成報(bào)表

查詢及統(tǒng)計(jì)各種信息

維護(hù)圖書信息

維護(hù)工作人員和管理員信息

維護(hù)借閱者信息

處理信息的完整性

對(duì)借閱過(guò)期的圖書生成報(bào)表

圖4-2圖書管理系統(tǒng)數(shù)據(jù)庫(kù)應(yīng)用需求的總結(jié)

根據(jù)以上所做的需求分析,并略掉一些細(xì)節(jié)(如不考慮用戶的登錄;對(duì)記錄的維護(hù)),得出以下的三層數(shù)據(jù)流圖。

§4.2系統(tǒng)功能模塊劃分

系統(tǒng)功能框圖如圖4-10所示。

§4.3系統(tǒng)數(shù)據(jù)庫(kù)設(shè)計(jì)

4.3.1概念設(shè)計(jì)

在概念設(shè)計(jì)階段中,設(shè)計(jì)人員從用戶的角度看待數(shù)據(jù)及處理要求和約束,產(chǎn)生一個(gè)反映用戶觀點(diǎn)的概念模式。然后再把概念模式轉(zhuǎn)換成邏輯模式。將概念設(shè)計(jì)從設(shè)計(jì)過(guò)程中獨(dú)立開(kāi)來(lái),使各階段的任務(wù)相對(duì)單一化,設(shè)計(jì)復(fù)雜程度大大降低,不受特定DBMS的限制。

利用ER方法進(jìn)行數(shù)據(jù)庫(kù)的概念設(shè)計(jì),可分成三步進(jìn)行:首先設(shè)計(jì)局部ER模式,然后把各局部ER模式綜合成一個(gè)全局模式,最后對(duì)全局ER模式進(jìn)行優(yōu)化,得到最終的模式,即概念模式。

(1)設(shè)計(jì)局部ER模式

實(shí)體和屬性的定義:

圖書(圖書編號(hào),圖書名稱,作者,出版社,出版日期,備注,價(jià)格,數(shù)量,)

借閱者(借書證號(hào),姓名,性別,身份證,聯(lián)系電話,密碼)

身份(身份編號(hào),身份描述,最大借閱數(shù))

圖書類別(圖書類別編號(hào),類別描述)

ER模型的“聯(lián)系”用于刻畫實(shí)體之間的關(guān)聯(lián)。一種完整的方式是對(duì)局部結(jié)構(gòu)中任意兩個(gè)實(shí)體類型,依據(jù)需求分析的結(jié)果,考察局部結(jié)構(gòu)中任意兩個(gè)實(shí)體類型之間是否存在聯(lián)系。若有聯(lián)系,進(jìn)一步確定是1:N,M:N,還是1:1等。還要考察一個(gè)實(shí)體類型內(nèi)部是否存在聯(lián)系,兩個(gè)實(shí)體類型之間是否存在聯(lián)系,多個(gè)實(shí)體類型之間是否存在聯(lián)系,等等。聯(lián)系定義如圖4-5所示。解釋如下:

u一個(gè)借閱者(用戶)只能具有一種身份,而一種身份可被多個(gè)借閱者所具有;

u一本圖書只能屬于一種圖書類別(類別),而一種圖書類別可以包含多本圖書;

u一個(gè)用戶可以借閱多本不同的書,而一本書也可以被多個(gè)不同的用戶所借閱。

(2)設(shè)計(jì)全局ER模式

所有局部ER模式都設(shè)計(jì)好了后,接下來(lái)就是把它們綜合成單一的全局概念結(jié)構(gòu)。全局概念結(jié)構(gòu)不僅要支持所有局部ER模式,而且必須合理地表示一個(gè)完整、一致的數(shù)據(jù)庫(kù)概念結(jié)構(gòu)。

1)確定公共實(shí)體類型

為了給多個(gè)局部ER模式的合并提供開(kāi)始合并的基礎(chǔ),首先要確定各局部結(jié)構(gòu)中的公共實(shí)體類型。在這一步中我們僅根據(jù)實(shí)體類型名和鍵來(lái)認(rèn)定公共實(shí)體類型。一般把同名實(shí)體類型作為公共實(shí)體類型的一類候選,把具有相同鍵的實(shí)體類型作為公共實(shí)體類型的另一類候選。

2)局部ER模式的合并

合并的原則是:首先進(jìn)行兩兩合并;先和合并那些現(xiàn)實(shí)世界中有聯(lián)系的局部結(jié)構(gòu);合并從公共實(shí)體類型開(kāi)始,最后再加入獨(dú)立的局部結(jié)構(gòu)。

3)消除沖突

沖突分為三類:屬性沖突、結(jié)構(gòu)沖突、命名沖突。

設(shè)計(jì)全局ER模式的目的不在于把若干局部ER模式形式上合并為一個(gè)ER模式,而在于消除沖突,使之成為能夠被所有用戶共同理解和接受的同一的概念模型。

3)全局ER模式的優(yōu)化

在得到全局ER模式后,為了提高數(shù)據(jù)庫(kù)系統(tǒng)的效率,還應(yīng)進(jìn)一步依據(jù)處理需求對(duì)ER模式進(jìn)行優(yōu)化。一個(gè)好的全局ER模式,除能準(zhǔn)確、全面地反映用戶功能需求外,還應(yīng)滿足下列條件:實(shí)體類型的個(gè)數(shù)要盡可能的少;實(shí)體類型所含屬性個(gè)數(shù)盡可能少;實(shí)體類型間聯(lián)系無(wú)冗余。

綜上所述,“圖書管理系統(tǒng)”的全局ER模式如圖4-13所示。

4.3.2關(guān)系數(shù)據(jù)庫(kù)的邏輯設(shè)計(jì)

由于概念設(shè)計(jì)的結(jié)果是ER圖,DBMS一般采用關(guān)系型(本人所使用的MSSQLServer就是關(guān)系型的DBMS),因此數(shù)據(jù)庫(kù)的邏輯設(shè)計(jì)過(guò)程就是把ER圖轉(zhuǎn)化為關(guān)系模式的過(guò)程。由于關(guān)系模型所具有的優(yōu)點(diǎn),邏輯設(shè)計(jì)可以充分運(yùn)用關(guān)系數(shù)據(jù)庫(kù)規(guī)范化理論,使設(shè)計(jì)過(guò)程形式化地進(jìn)行。設(shè)計(jì)結(jié)果是一組關(guān)系模式的定義。

(1)導(dǎo)出初始關(guān)系模式

book(圖書編號(hào)#,圖書名稱,圖書類別#,作者,出版社,出版日期,備注,價(jià)格,數(shù)量)class(圖書類別#,類別名)user(借書證號(hào)#,姓名,性別,身份編號(hào)#,身份證,聯(lián)系電話,密碼)ID(身份編號(hào)#,身份描述,最大借閱數(shù))Owner(借書證號(hào)#,圖書編號(hào)#,借書日期)

圖4-14關(guān)系模式集

(2)產(chǎn)生子模式

子模式是用戶所用到的那部分?jǐn)?shù)據(jù)的描述。除了指出用戶用到的數(shù)據(jù)外,還應(yīng)指出數(shù)據(jù)與概念模式中相應(yīng)數(shù)據(jù)的聯(lián)系,即指出概念模式與子模式之間的對(duì)應(yīng)性。

借書子模式(借書證號(hào)#,姓名,圖書編號(hào)#,圖書名稱,借書日期)

圖4-15部分子模式

(3)根據(jù)設(shè)計(jì)中出現(xiàn)的問(wèn)題本人在寫系統(tǒng)時(shí)還加入了兩個(gè)關(guān)系模式:

1、ownertemp:用于工作人員在處理借書、還書工作時(shí)臨時(shí)存儲(chǔ)借書、還書信息,以便打印報(bào)表時(shí)使用。

2、keyer:用于存儲(chǔ)工作人員和圖書館管理員的用戶名和密碼及權(quán)限,以便工作人員或圖書館管理員進(jìn)入相應(yīng)的功能模塊時(shí)進(jìn)行驗(yàn)證用戶的身份。

4.3.3數(shù)據(jù)庫(kù)的實(shí)現(xiàn)

我選用MicrosoftSQLServer2000(企業(yè)版)數(shù)據(jù)庫(kù)來(lái)進(jìn)行數(shù)據(jù)庫(kù)的邏輯設(shè)計(jì)。首先創(chuàng)建七個(gè)基本數(shù)據(jù)庫(kù)表如表4-1-4-7所示,然后根據(jù)全局ER圖,建立各個(gè)表之間的聯(lián)系,如圖4-8所示。

表4-1借閱者基本信息表的結(jié)構(gòu)(User)

表4-2圖書信息表的結(jié)構(gòu)(Book)

表4-3圖書類別信息表的結(jié)構(gòu)(Class)

表4-4借閱者身份信息表的結(jié)構(gòu)(ID)

表4-5借閱情況信息表的結(jié)構(gòu)(Owner)

表4-6借閱情況臨時(shí)存儲(chǔ)信息表的結(jié)構(gòu)(Ownertemp)

注:在owner表和ownertemp表中加入了索引字段,用來(lái)唯一標(biāo)識(shí)一條借書記錄,并且設(shè)置為標(biāo)識(shí),標(biāo)識(shí)種子為1。

表4-7工作人員和管理員信息表的結(jié)構(gòu)(Keyer)

圖4-8數(shù)據(jù)庫(kù)表間聯(lián)系圖

第五章圖書管理系統(tǒng)應(yīng)用程序設(shè)計(jì)

§5.1系統(tǒng)窗體模塊組成

§5.2數(shù)據(jù)模塊窗體的設(shè)置

在編寫數(shù)據(jù)庫(kù)應(yīng)用程序時(shí),經(jīng)常要遇到這樣的情況,即好多組件、窗體同時(shí)訪問(wèn)相同的數(shù)據(jù)源,如果為每一個(gè)組件或者窗體都設(shè)置一個(gè)數(shù)據(jù)源將是十分耗時(shí)的工件,而且要保證這些數(shù)據(jù)源的確是相同的也需花一番功夫。那么,能不能將這些數(shù)據(jù)源集中管理,最好是做成一個(gè)統(tǒng)一的模塊,需要時(shí)就將該模塊引入而不必直接操作數(shù)據(jù)源本身呢?數(shù)據(jù)模塊(DataModule)是解決這個(gè)問(wèn)題最好的答案。簡(jiǎn)單說(shuō)來(lái),數(shù)據(jù)模塊是用來(lái)集中管理數(shù)據(jù)源的一個(gè)窗體,該窗體可被需要的地方隨時(shí)引入。

但本人在開(kāi)發(fā)這個(gè)系統(tǒng)時(shí),開(kāi)始使用了一下數(shù)據(jù)模塊,但在使用過(guò)程中卻碰到了一些問(wèn)題。并且考慮這個(gè)系統(tǒng)使用到的TADOQuery控件比較多,如果使用數(shù)據(jù)控件可能會(huì)帶來(lái)管理上的麻煩,如弄混各個(gè)數(shù)據(jù)控件的作用。還考慮到使用動(dòng)態(tài)生成ADOQuery可能會(huì)更節(jié)省資源。所以在本人的系統(tǒng)中,開(kāi)始做的第一個(gè)模塊“借閱者個(gè)人模塊”中還稍微使用了一下數(shù)據(jù)模塊。但在后面做的兩個(gè)模塊中大多都是用動(dòng)態(tài)生成ADOQuery來(lái)實(shí)現(xiàn)的。并且由于SQL語(yǔ)句是動(dòng)態(tài)加入的所以datamodule中的控件也不會(huì)多。

§5.3啟動(dòng)畫面的實(shí)現(xiàn)

啟動(dòng)畫面是為了給用戶一個(gè)良好的印像,加深軟件的親和力,沒(méi)有實(shí)際的功能,在Form1窗體中加入了Image和Time組件。啟動(dòng)畫面的窗體略,主要的源代碼如下:

§5.4用戶登錄窗體的的實(shí)現(xiàn)

本窗體是為三種不同的用戶(一般用戶,工作人員,管理員)提供選擇以進(jìn)入不同的模塊,滿足不同用戶的需求。源代碼比較簡(jiǎn)單,略。

§5.5用戶密碼認(rèn)證窗體的的實(shí)現(xiàn)

本窗體是為了讓工作人員或圖書館管理員按照用戶名和密碼進(jìn)行登錄,并且跟據(jù)用戶名檢查Keyer表中的“權(quán)限”字段,以分辯進(jìn)入圖書館管理人員模塊還是進(jìn)入工作人員模塊。窗體界面、源代碼如下

§5.6借閱者服務(wù)模塊的實(shí)現(xiàn)

借閱者服務(wù)窗體的功能主要是圖書的查詢,個(gè)人借閱情況查看及個(gè)人部分信息的修改。界面圖如下:

5.6.1圖書查詢功能的實(shí)現(xiàn)

在本系統(tǒng)中,任何人都有權(quán)限使用查詢功能,不做任何限制。界面如下,

由于實(shí)現(xiàn)的查詢功能有多種,如按圖書編號(hào)、圖書名稱等字段進(jìn)行完全體配查找和部分體配的模糊查找,還有按多個(gè)條件進(jìn)行邏輯與或是邏輯或的多條件查找。其中實(shí)現(xiàn)的方法者差不多,所以只給出多條件查找的代碼,如下:

5.6.2借閱者登錄功能的實(shí)現(xiàn)

這個(gè)功能的實(shí)現(xiàn)與工作人員和管理人員登錄功能實(shí)現(xiàn)的方法大致一樣,并且還要簡(jiǎn)單。是從User表中查到到借閱證號(hào)與密碼,看與用戶輸入的是否一致。如果一致,那么用戶就可查看自已的借閱情況并維護(hù)自己的部分信息。源代碼與借閱者登錄界面都略。

5.6.3借閱者借閱情況功能的實(shí)現(xiàn)

當(dāng)借閱者正確登錄到系統(tǒng)后,此功能將被激活,使用戶能查看到自身的借閱情況。在此系統(tǒng)中,信息的顯示一般用ListView來(lái)實(shí)現(xiàn),只在較少的情況下用到了DBgrid,因?yàn)槲矣X(jué)得ListView更好實(shí)現(xiàn),并能使信息數(shù)據(jù)對(duì)用戶的完全分離。

在這里跟據(jù)借閱者的不同要求實(shí)現(xiàn)借閱情況的查詢,有檢查所有的借閱情部、某本書的借閱情況、和根據(jù)已借閱天數(shù)的來(lái)查詢。其中根椐借閱天數(shù)來(lái)查詢更有代表性,有方式一和方式二。以下給出此功能的源代碼

按借閱天數(shù)查詢方式一

按借閱天數(shù)查詢方式二

5.6.4借閱者個(gè)人資料維護(hù)功能的實(shí)現(xiàn)

此功能實(shí)現(xiàn)當(dāng)前借閱者部份資料的修改,但借書證號(hào)和身份類別這樣的信息不允許修改,這是圖書館管理員模塊的功能。在此界面中點(diǎn)擊修改按鈕將出現(xiàn)“修改”窗體(Form8),點(diǎn)擊修改密碼按鈕將出現(xiàn)groupbox8,在這里進(jìn)行密碼修改。關(guān)鍵源代碼如下。

這里給出個(gè)人部分信息修改的源代碼:

這里給出密碼修改的源代碼:

5.7工作人員-圖書借閱/歸還模塊的實(shí)現(xiàn)

5.7.1工作人員進(jìn)行圖書借閱功能實(shí)現(xiàn)

在這個(gè)功能中,工作人員輸入借閱者的借閱證號(hào)和所要借閱的圖書的圖書編號(hào),然后點(diǎn)擊借閱按鈕就可進(jìn)行圖書借閱。考慮到實(shí)際中可能會(huì)出現(xiàn)只知圖書名而不知圖書編號(hào)的情況,在此界面下方加入了一個(gè)轉(zhuǎn)換功能,可以把圖書名稱轉(zhuǎn)換成圖書編號(hào),再進(jìn)行圖書借閱。

在借閱完成后會(huì)生借閱報(bào)表以便借閱者檢查和確認(rèn),借閱報(bào)表的打印效果如下圖,實(shí)現(xiàn)比較簡(jiǎn)單,略去實(shí)現(xiàn)過(guò)程。

5.7.2工作人員進(jìn)行圖書歸還功能實(shí)現(xiàn)

在此功能中,工作人員根據(jù)借閱者的借書證號(hào)和歸還的圖書編號(hào)進(jìn)行圖書的歸還工作。并且根據(jù)現(xiàn)實(shí)中可能會(huì)出現(xiàn)的只知圖書名不知圖書編號(hào)的歸還情況,所以加入了按書籍名稱進(jìn)行歸還的功能。這個(gè)功能是圖書借閱功能中把圖書名稱轉(zhuǎn)換成圖書編號(hào)的一種改進(jìn)方法,這樣就不用如借閱功能中一樣要先轉(zhuǎn)換再借閱了。歸還完成后,同樣會(huì)打印出歸還報(bào)表以便用戶檢查和確認(rèn)。

5.8圖書館管理員模塊的實(shí)現(xiàn)

5.8.1圖書館管理員圖書管理功能的實(shí)現(xiàn)

在這個(gè)功能中可以在(*圖書編號(hào))中輸入圖書編號(hào),點(diǎn)查找按鈕后就會(huì)在各個(gè)相應(yīng)的組件中顯示出信息,或按圖書名稱模糊查找到所要的記錄,在各個(gè)相應(yīng)的組件中顯示第一條記錄的信息,也可在下端的ListView組件中點(diǎn)擊某一條記錄,在各個(gè)相應(yīng)的組件中也會(huì)顯示所選記錄的信息。在入庫(kù)功能中只要不是相同的圖書編號(hào)并且?guī)В?hào)提示的字段不為空就可插入新的圖書記錄。刪除則刪除那些Book表中的圖書記錄,如果借出還可依用戶要求連帶刪除owner表中的記錄。因?yàn)閳D書修改與圖書入庫(kù)的功能與工作人員記錄修改和工作人員記錄添加的實(shí)現(xiàn)過(guò)程一樣,所以下面僅給出刪除功能的源代碼,如下

5.8.2圖書館管理員工作人員和管理員管理功能的實(shí)現(xiàn)

在此功能中可以加入工作人員或是管理員,或是修改他們的密碼、權(quán)限。

在此功能中如果選中ListView中的記錄,則在右邊相應(yīng)的組件中顯示出信息,并且管理員還可對(duì)這些記錄進(jìn)行修改或加入新的記錄。并且也可以點(diǎn)刪除按鈕刪除選中的一條或多條記錄。刪除功能與圖書記錄的刪除一般,所以下面只給出添加與修改的實(shí)現(xiàn)過(guò)程。

5.8.3圖書館管理員修改圖書類別及統(tǒng)記功能的實(shí)現(xiàn)

在此窗體中能對(duì)圖書的類別進(jìn)行刪除,添加和修改,這模塊的功能的實(shí)現(xiàn)過(guò)程與圖書記錄的刪除,添加和修改一樣的,但是這個(gè)窗體還能跟據(jù)圖書類別進(jìn)行統(tǒng)計(jì),還可根據(jù)Book表和owner表統(tǒng)計(jì)出圖書總數(shù)目,庫(kù)存圖書數(shù)目,借出圖書數(shù)目及借閱過(guò)期的圖書數(shù)目。在這里給出統(tǒng)計(jì)圖書總數(shù)目,庫(kù)存圖書數(shù)目,借出圖書數(shù)目及借閱過(guò)期的圖書數(shù)目的實(shí)現(xiàn)過(guò)程中的幾個(gè)函數(shù)和過(guò)程

5.8.4圖書館管理員借閱者管理功能的實(shí)現(xiàn)

查詢借閱者可根據(jù)借閱者的借書證號(hào)或姓名或身份編號(hào)查找到借閱者的信息,也可以實(shí)行模糊查找,這個(gè)功能的實(shí)現(xiàn)與前面圖書查找的實(shí)現(xiàn)過(guò)程一般,就不再詳細(xì)說(shuō)明。

5.8.5圖書館維護(hù)借閱者管理功能的實(shí)現(xiàn)

此功能能對(duì)借閱者信息進(jìn)行查看添加、刪除、修改。在這里給出刷新按鈕的實(shí)現(xiàn)過(guò)程

5.8.6圖書館身份維護(hù)功能的實(shí)現(xiàn)

篇4

VFP中有一種名為“項(xiàng)目管理器”的管理工具,它可以對(duì)圖書以及圖書銷售信息的數(shù)據(jù)、文檔以及源代碼等進(jìn)行集中記錄和管理,使各種信息分類明確、條理清晰,便于人們查找。

1.2信息的查詢

VFP采用了先進(jìn)的Rushmore快速查詢技術(shù),系統(tǒng)能從記錄著眾多圖書及其銷售信息的數(shù)據(jù)庫(kù)表中迅速篩選出人們所需要的內(nèi)容,整個(gè)查詢響應(yīng)時(shí)間只有數(shù)秒鐘,非常迅速與高效。

1.3建立信息之間的關(guān)聯(lián)

一般數(shù)據(jù)庫(kù)管理系統(tǒng)中的各項(xiàng)信息都是相互獨(dú)立的,每一項(xiàng)信息與其他信息之間并無(wú)關(guān)聯(lián),除非通過(guò)編程命令來(lái)專門描述;而VFP卻在這方面做出了改善,它可以在建表初期就把相關(guān)信息關(guān)聯(lián)起來(lái),便于人們引用。

2基于VFP的圖書銷售管理系統(tǒng)的設(shè)計(jì)與開(kāi)發(fā)

以VFP為基礎(chǔ)對(duì)圖書銷售管理系統(tǒng)進(jìn)行設(shè)計(jì)與開(kāi)發(fā),大體可以分為以下幾個(gè)步驟。

2.1前期規(guī)劃與需求分析階段

在建立圖書銷售管理系統(tǒng)數(shù)據(jù)庫(kù)之前,一定要先做好規(guī)劃工作,因?yàn)樗苯佑绊懻麄€(gè)數(shù)據(jù)庫(kù)建立的全局運(yùn)作,關(guān)系到數(shù)據(jù)庫(kù)建立的成功與否。具體來(lái)說(shuō),前期規(guī)劃內(nèi)容主要包括:對(duì)建立數(shù)據(jù)庫(kù)的必要性和可行性進(jìn)行分析,以及確定VFP數(shù)據(jù)庫(kù)在整個(gè)圖書銷售管理系統(tǒng)中所處的地位。然后進(jìn)行需求分析。需求分析指的是,通過(guò)與出版社的相關(guān)工作人員進(jìn)行交流與訪談,從而獲知其管理水平、需求情況、發(fā)展目標(biāo)和計(jì)算機(jī)軟硬件設(shè)施條件等信息,再根據(jù)這些信息來(lái)對(duì)圖書銷售管理系統(tǒng)進(jìn)行規(guī)劃設(shè)計(jì),使系統(tǒng)更加符合人們的需求,更加人性化。

2.2物理設(shè)計(jì)階段

基于VFP對(duì)圖書銷售管理系統(tǒng)進(jìn)行物理設(shè)計(jì),主要指的是根據(jù)管理系統(tǒng)的數(shù)據(jù)模型以及計(jì)算機(jī)的系統(tǒng)類型等,對(duì)數(shù)據(jù)庫(kù)的物理結(jié)構(gòu)(包括存儲(chǔ)結(jié)構(gòu)與存取方法)進(jìn)行設(shè)計(jì)。物理設(shè)計(jì)的主要目的是為了使計(jì)算機(jī)的存儲(chǔ)空間得到充分利用,從而提高管理系統(tǒng)的工作效率。

2.3模塊設(shè)計(jì)階段

基于VFP對(duì)圖書銷售管理系統(tǒng)進(jìn)行模塊設(shè)計(jì),主要指的是把管理系統(tǒng)數(shù)據(jù)庫(kù)中所需要記錄和統(tǒng)計(jì)的各項(xiàng)信息———如讀者的個(gè)人信息、讀者的訂單信息、出版社或書店的書庫(kù)信息、讀者的購(gòu)書及退書信息、讀者的反饋信息、企業(yè)的賬簿信息以及管理處信息等,按照不同的分類進(jìn)行模塊劃分,并且在劃分時(shí)要注意各項(xiàng)信息之間的關(guān)聯(lián)。當(dāng)然,不同工作人員在設(shè)計(jì)過(guò)程當(dāng)中還需要分工合作,每個(gè)人負(fù)責(zé)一項(xiàng)專門的工作,這樣才能提高工作效率。比如,由圖書銷售人員負(fù)責(zé)管理賬戶的創(chuàng)建和修改,并管理讀者及讀者訂單的信息、檢索書籍的信息和統(tǒng)計(jì)每日賬目等;由倉(cāng)庫(kù)管理人員負(fù)責(zé)管理書庫(kù)的信息(包括錄入與查詢等)。舉例來(lái)說(shuō),一種較為常見(jiàn)的基于VFP的圖書銷售管理系統(tǒng)會(huì)有以下五大模塊:讀者信息模塊、讀者訂單信息模塊、書庫(kù)信息模塊、銀行(賬簿)信息模塊、管理處信息模塊,每個(gè)模塊都具有其獨(dú)特的功能。

2.2.1讀者信息模塊

讀者信息模塊主要有3個(gè)功能,即編輯讀者信息功能(如對(duì)讀者的姓名、性別、身份、電話、住址、E-mail等信息進(jìn)行添加、修改和刪除等)、檢索讀者信息功能(此功能是讀者信息模塊最重要的功能,它能以單一或者組合兩種條件來(lái)對(duì)相關(guān)讀者的信息進(jìn)行匹配與查找,檢索的字段亦包括讀者的姓名、性別、身份、電話、住址、E-mail等,條件的匹配可以是“大于”“小于”“等于”“不等于”“包含”“在……”等多種形式,條件的組合也有“與”和“或”兩種形式)和打印讀者信息功能。

2.2.2讀者訂單信息模塊

讀者訂單信息模塊主要有3個(gè)功能,即編輯讀者訂單信息功能(如對(duì)讀者的姓名以及聯(lián)系方式,所訂圖書的書名、作者、出版社、訂單號(hào)、單價(jià)、數(shù)量、總價(jià)、下單日期等信息進(jìn)行添加、修改和刪除等)、檢索讀者訂單信息功能(此功能是讀者訂單信息模塊最重要的功能,同樣能以單一或者組合兩種條件來(lái)對(duì)相關(guān)讀者訂單的信息進(jìn)行匹配與查找,檢索的字段包括讀者的姓名以及聯(lián)系方式,所訂圖書的書名、作者、出版社、訂單號(hào)、單價(jià)、數(shù)量、總價(jià)、下單日期等,條件的匹配有“大于”“小于”“等于”“不等于”“包含”“在……”等多種形式,條件的組合有“與”和“或”兩種形式)和打印讀者訂單信息功能。

2.2.3書庫(kù)信息模塊

書庫(kù)模塊又細(xì)分為存書查詢、購(gòu)書和退書3個(gè)子模塊。存書查詢模塊主要有3個(gè)功能,即編輯存書信息功能(如對(duì)圖書的書名、作者、出版社、售價(jià)、庫(kù)存數(shù)量、出版日期等信息進(jìn)行添加、修改和刪除等)、檢索存書信息功能(與讀者信息模塊和讀者訂單信息模塊類似)和打印存書信息功能。購(gòu)書模塊主要有3個(gè)功能,即編輯購(gòu)書信息功能(如對(duì)購(gòu)買圖書的書名、作者、出版社、單價(jià)、數(shù)量、總價(jià)等信息進(jìn)行添加、修改和刪除等)、檢索購(gòu)書信息功能(與讀者信息模塊和讀者訂單信息模塊類似)和打印購(gòu)書信息功能。退書模塊亦主要有3個(gè)功能,即編輯退書信息功能(如對(duì)所退圖書的書名、作者、出版社、單價(jià)、數(shù)量、總價(jià)、退書原因等信息進(jìn)行添加、修改和刪除等)、檢索退書信息功能(與讀者信息模塊和讀者訂單信息模塊類似)和打印退書信息功能。

2.2.4銀行(賬簿)信息模塊

銀行(賬簿)信息模塊主要有3個(gè)功能,即編輯銀行(賬簿)信息功能(如對(duì)圖書銷售的總額、費(fèi)用支出、凈收入、余額和日期等信息進(jìn)行添加、修改和刪除等)、檢索銀行(賬簿)信息功能(與讀者信息模塊和讀者訂單信息模塊類似)和打印銀行(賬簿)信息功能。

2.2.5管理處信息模塊

管理處信息模塊主要有3個(gè)功能,即編輯管理處信息功能(如對(duì)各項(xiàng)事件的記錄、備注和日期等信息進(jìn)行添加、修改和刪除等)、檢索管理處信息功能(與讀者信息模塊和讀者訂單信息模塊類似)和打印管理處信息功能。

2.4實(shí)施和運(yùn)行階段

基于VFP的圖書銷售管理系統(tǒng)在完成前期規(guī)劃與需求分析、物理設(shè)計(jì)以及模塊設(shè)計(jì)之后,可以開(kāi)始試運(yùn)行。這一階段也可以稱為調(diào)試或試驗(yàn)階段,是對(duì)管理系統(tǒng)的具體操作實(shí)踐和試用。在此期間,工作人員要仔細(xì)觀察和體驗(yàn)系統(tǒng)的運(yùn)行與使用情況,并將出現(xiàn)的各種問(wèn)題進(jìn)行詳細(xì)記錄,同時(shí)也要做好數(shù)據(jù)的備份和轉(zhuǎn)存工作,以免系統(tǒng)出現(xiàn)故障導(dǎo)致數(shù)據(jù)丟失。觀察與記錄完畢之后,相關(guān)人員還要對(duì)系統(tǒng)運(yùn)行中所出現(xiàn)的不良狀況和故障進(jìn)行探討與分析,并加以改進(jìn),直到系統(tǒng)可以正常運(yùn)行為止。

篇5

總體來(lái)說(shuō)就是在自己的計(jì)算機(jī)上,為實(shí)現(xiàn)讀書治學(xué)的目的,使雜亂無(wú)章的信息資源變成有組織的信息集合,通過(guò)免費(fèi)的或基本免費(fèi)的軟件,將網(wǎng)上的有關(guān)信息資源,通過(guò)該管理軟件進(jìn)行存取,在軟件內(nèi)完成編輯管理,根據(jù)個(gè)人需求,供其有效利用。個(gè)人數(shù)字圖書館的意義在于,通過(guò)這一軟件系統(tǒng),對(duì)于個(gè)人知識(shí)儲(chǔ)備的數(shù)字化整合可以順利完成,用戶能夠自己創(chuàng)建、維護(hù)、使用該軟件系統(tǒng)。

這一新形式的個(gè)人數(shù)字圖書館與傳統(tǒng)圖書館比較,突出的特點(diǎn)是:

(1)數(shù)字化。使紙質(zhì)資料的文獻(xiàn)形態(tài)改變,使其數(shù)字化。曾經(jīng)的紙質(zhì)圖書存放時(shí)間較長(zhǎng)后,其一、積少成多,體積增大,內(nèi)容增多,越來(lái)越不利于文獻(xiàn)資料的整理和保存,其二、隨著時(shí)間的推移,部分資料由于保管不善肯定會(huì)發(fā)生丟失損毀,舊資料查找時(shí)也是一個(gè)大工程,那么如何處理這些破舊書刊紙質(zhì)資料?去粗存精選擇性保管顯然不是最理想的方法,那么使其數(shù)字化可以妥善保存,不遺失資料的同時(shí)更加能夠便于查找。

(2)數(shù)據(jù)庫(kù)化。當(dāng)今,互聯(lián)網(wǎng)上供人免費(fèi)下載的數(shù)字資源日益增多,大家將自己感興趣的文件和資料下載到本地電腦的文件夾中,供日后查閱或使用。但是文件夾不具有數(shù)據(jù)庫(kù)結(jié)構(gòu),并不能有效的進(jìn)行檢索文件,當(dāng)我們下載的文件日益增多的時(shí)候,無(wú)法有效的管理這些下載的文件,那么,就可以通過(guò)個(gè)人數(shù)字圖書館對(duì)其進(jìn)行統(tǒng)一管理,在需要時(shí)通過(guò)搜索引擎,快速準(zhǔn)確的查找到目標(biāo)文件,無(wú)論文檔文件還是圖片文件或是視頻文件,均可自動(dòng)識(shí)別并打開(kāi)后臺(tái)運(yùn)行,操作簡(jiǎn)單,使用方便。

(3)檢索功能增強(qiáng)化。因?yàn)閭€(gè)人數(shù)字圖書館的使用者們并不是專業(yè)的情報(bào)學(xué)工作人員,無(wú)法精確的對(duì)于所需檢索的內(nèi)容進(jìn)行輸入,所以,要快速準(zhǔn)確的查找到文獻(xiàn)資料,在檢索功能的設(shè)置上要加強(qiáng),即使是模糊的搜索關(guān)鍵詞也一樣能迅速的找到需要的文獻(xiàn)資料。基本的檢索功能中至少具有字段檢索、單項(xiàng)檢索、截詞檢索、全庫(kù)掃描檢索等,并且,各種類型的文件要在統(tǒng)一的檢索界面,使用方便查找快捷,檢索歷史隨時(shí)保存便于隨時(shí)調(diào)用。

2 個(gè)人數(shù)字圖書館論文管理系統(tǒng)在高校應(yīng)用的可行性研究與分析

在高校設(shè)立個(gè)人數(shù)字圖書館論文管理系統(tǒng),不僅為學(xué)生讀者帶來(lái)很大方便,同時(shí)在系統(tǒng)設(shè)計(jì)初期的可行性研究與分析中得出其具有很多的優(yōu)勢(shì),下面將通過(guò)3個(gè)方面詳述分析。

(1)高校圖書館豐富的信息資源,配合校園內(nèi)完善的網(wǎng)絡(luò)環(huán)境。豐富的館藏資源,電子文獻(xiàn)資料較全,是高校圖書館館藏的重要特點(diǎn),面向高校大學(xué)生,購(gòu)買了種類豐富的各類論文數(shù)據(jù)庫(kù)供學(xué)生學(xué)習(xí)查閱,同時(shí)自建論文數(shù)據(jù)資料庫(kù),為學(xué)生查閱下載論文資料提供了很大的方便。另外,高校的現(xiàn)代化設(shè)施建設(shè)完善,如學(xué)生宿舍的高速網(wǎng)絡(luò)、圖書館的電子閱覽室、校園全網(wǎng)無(wú)線覆蓋等,這些設(shè)施為個(gè)人數(shù)字圖書館的建設(shè)提供了堅(jiān)實(shí)的基礎(chǔ)和現(xiàn)實(shí)保障。

(2)借鑒國(guó)內(nèi)外成功的案例,為我們提供了寶貴經(jīng)驗(yàn)。美國(guó)康奈爾大學(xué)圖書館曾成功開(kāi)發(fā)個(gè)人數(shù)字圖書館平臺(tái)――My liberty。用戶可以自行通過(guò)該平臺(tái)搜集電子資源,既可以來(lái)自公共網(wǎng)絡(luò)的任何地方,也可以來(lái)自校園網(wǎng)絡(luò)的內(nèi)部門戶,在這個(gè)平臺(tái)上管理、編輯、下載,打造屬于自己的個(gè)人圖書館。在國(guó)內(nèi),浙江大學(xué)也曾成功開(kāi)發(fā)“我的圖書館”,系統(tǒng)功能如:新書通告、數(shù)字資源定制、搜索引擎、書簽功能、個(gè)人信息保護(hù)等。雖然開(kāi)發(fā)項(xiàng)目不是完全相同,但這些成功的案例都具有一定的可借鑒性。

(3)數(shù)量穩(wěn)定的受眾用戶群。高校龐大的用戶群體都具有高學(xué)識(shí)、高素質(zhì),比較熟練掌握計(jì)算機(jī)應(yīng)用、網(wǎng)絡(luò)通訊知識(shí)、文獻(xiàn)檢索知識(shí)等,他們無(wú)論是論文創(chuàng)作還是課題研發(fā),都需要強(qiáng)大的學(xué)術(shù)資料支持,這一軟件系統(tǒng)可以為他們提供高水平、多層次的個(gè)性化信息服務(wù),相信廣大師生都能夠廣泛的參與其中,構(gòu)成穩(wěn)定的軟件系統(tǒng)的受眾群體。

3 個(gè)人數(shù)字圖書館論文管理系統(tǒng)的開(kāi)發(fā)構(gòu)想

根據(jù)個(gè)人數(shù)字圖書館的基本研究發(fā)現(xiàn),個(gè)人數(shù)字圖書館的數(shù)字化、數(shù)據(jù)庫(kù)化特點(diǎn),以及高等學(xué)校的軟硬件設(shè)施和環(huán)境,以及推廣使用面向的目標(biāo)群體,非常便于個(gè)人數(shù)字圖書館論文管理系統(tǒng)的開(kāi)發(fā)與利用。