

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、<p> 圖書管理系統(tǒng)畢業(yè)設計</p><p><b> 摘 要</b></p><p> 圖書管理系統(tǒng)是典型的信息管理系統(tǒng),其開發(fā)主要包括后臺數據庫的建立和維護以及前端應用程序的開發(fā)兩個方面。對于前者要求建立起數據一致性和完整性強、數據安全性好的庫。而對于后者則要求應用程序功能完備,易使用等特點。</p><p> 因此
2、要求結合開入式圖書館的要求,對MS SQL Server2000數據庫管理系統(tǒng)、SQL語言原理、完成對圖書管理系統(tǒng)的需求分析、功能模塊劃分、數據庫模式分析,并由此設計了數據庫結構和應用程序。</p><p> 第一章對數據庫應用系統(tǒng)開發(fā)和圖書管理系統(tǒng)進行了簡明的介紹,并分析了開發(fā)圖書管理系統(tǒng)所應進行的工作。第二章對數據庫的設計和SQL語言的使用進行了系統(tǒng)分析,為深入理解數據庫應用打下了基礎。第三章學習了具體的開
3、發(fā)工具Delphi 6.0,對其數據庫組件,SQL語言在Delphi中的應用等數據庫編程關鍵技術進行了系統(tǒng)的介紹。第四章分析了圖書管理信息系統(tǒng)的應用需求,按照數據庫設計理論的要求給出了系統(tǒng)需求說明書、局部ER圖、全局ER圖、系統(tǒng)關系模式,子模式,利用MS SQL Server2000建立了數據庫。第五章進行了具體的程序設計,具體劃分了三類用戶的操作權限,設計了了三個操作界面。實現了數據庫表的瀏覽,記錄的添加、刪除和修改,報表的生成,實現
4、了多數據庫表的連接操作,實現了多條件查詢和模糊查詢,并靈活實現了對不可更新查詢結果集的更新操作,實現了主從表操作,實現了密碼維護功能,最后,系統(tǒng)還可以導入數據庫以對任意同結構的數據庫進行操作設計充分利用Delphi 6、MS SQL Server2000數據庫。</p><p> 關鍵詞:數據庫,MS SQL Server,Delphi,數據庫,圖書,管理</p><p><b&g
5、t; 目 錄</b></p><p><b> 1前 言4</b></p><p> 1.1數據庫應用系統(tǒng)開發(fā)簡介4</p><p> 1.1.1數據庫4</p><p> 1.1.2數據庫管理系統(tǒng)5</p><p> 1.1.3創(chuàng)建數據庫5<
6、;/p><p> 1.2圖書管理系統(tǒng)6</p><p> 1.3系統(tǒng)所做工作6</p><p> 2數據庫理論基礎7</p><p> 2.1數據庫系統(tǒng)設計及范式分析7</p><p> 2.1.1數據庫系統(tǒng)設計7</p><p> 2.1.2數據庫設計范式分析9
7、</p><p> 2.2SQL語言介紹9</p><p> 2.2.1SQL基礎9</p><p> 2.2.2SQL語句10</p><p> 3應用系統(tǒng)開發(fā)工具11</p><p> 3.1Delphi6.0 VCL組件的體系結構12</p><p> 3.
8、2數據庫組件介紹12</p><p> 3.3SQL語言在Delphi中的應用13</p><p> 3.4MS SQL Server簡述15</p><p> 4圖書管理系統(tǒng)設計分析16</p><p> 4.1需求分析16</p><p> 4.2系統(tǒng)數據庫設計17</p&g
9、t;<p> 4.2.1概念設計17</p><p> 4.2.2關系數據庫的邏輯設計18</p><p> 4.2.3數據庫的實現18</p><p> 5圖書管理系統(tǒng)應用程序設計19</p><p> 5.1系統(tǒng)窗體模塊組成19</p><p> 5.2數據模塊窗體的
10、設置20</p><p> 5.3啟動畫面的實現20</p><p> 5.4用戶登錄窗體的的實現20</p><p> 5.5用戶密碼認證窗體的的實現20</p><p> 5.6借閱者服務模塊的實現20</p><p> 5.6.1圖書查詢功能的實現20</p><
11、;p> 5.6.2借閱者登錄功能的實現20</p><p> 5.6.3借閱者借閱情況功能的實現20</p><p> 5.6.4借閱者個人資料維護功能的實現21</p><p> 5.7工作人員-圖書借閱/歸還模塊的實現21</p><p> 5.7.1工作人員進行圖書借閱功能實現21</p>
12、<p> 5.7.2工作人員進行圖書歸還功能實現21</p><p> 5.8圖書館管理員模塊和管理員圖書管理功能的實現21</p><p> 5.8.1圖書館管理員工作人員和管理員管理功能的實現21</p><p> 5.8.2圖書館管理員修改圖書類別及統(tǒng)記功能的實現21</p><p> 5.8.3
13、圖書館管理員借閱者管理功能的實現22</p><p> 5.8.4圖書館維護借閱者管理功能的實現22</p><p> 5.8.5圖書館身份維護功能的實現22</p><p> 5.8.6圖書館借閱者統(tǒng)計功能的實現22</p><p> 5.8.7圖書館統(tǒng)計借閱過期記錄功能的實現22</p><
14、p><b> 結 束 語23</b></p><p><b> 致 謝24</b></p><p><b> 參考文獻25</b></p><p><b> 附錄26</b></p><p><b> 前 言</
15、b></p><p> 數據庫應用系統(tǒng)開發(fā)簡介</p><p> 在數據庫應用系統(tǒng)開發(fā)之前,對開發(fā)數據庫的基本概念應當了解,對數據庫的結構、開發(fā)數據庫應用程序的步驟、開發(fā)體系及方法都應當有相當清晰的了解和認識。</p><p> 數據庫應用系統(tǒng)開發(fā)的目標是建立一個滿足用戶長期需求的產品。開發(fā)的主要過程為:理解用戶的需求,然后,把它們轉變?yōu)橛行У臄祿煸O計
16、。把設計轉變?yōu)閷嶋H的數據庫,并且這些數據庫帶有功能完備、高效能的應用。</p><p> 數據庫技術在計算機軟件鄰域研究中一直是非常重要的主題,產生于60年代,30多年來數據庫技術得到了迅速發(fā)展,并已形成較為完整的理論體系和一大批實用系統(tǒng)。并且,近年來,隨著World Wide Web(WWW)的猛增及Internet技術的迅速發(fā)展,使得數據庫技術之時成為最熱門技術之一。</p><p>
17、;<b> 數據庫</b></p><p> 數據庫由DBMS(數據庫管理系統(tǒng))處理,DBMS則由開發(fā)人員和用戶通過應用程序直接或間接地使用。它主要包括四個要素:用戶數據、元數據、索引和應用元數據。</p><p><b> 用戶數據</b></p><p> 目前,大多數主流數據庫管理系統(tǒng)把用戶數據表示為關系?,F
18、在把關系看作數據表。表的列包含域或屬性,表的行包含對應業(yè)務環(huán)境中的實體的記錄。并非所有的關系都同樣符合要求,有些關系比其它關系更結構化一些。第二章描述了一個用以產生良好結構關系的過程,稱作規(guī)范化。</p><p> 為了對比結構差的關系和結構好的關系之間的差別,以本文所設計的圖書管理系統(tǒng)中的圖書和圖書借閱者關系為例來說明,假若設計關系R1(借書證號,姓名,性別,身份編號,身份證,聯(lián)系電話,圖書編號,圖書名稱,圖
19、書類別,作者,出版社,出版日期,備注,價格,數量);這個關系的問題出在它有關于兩個不同主題的數據,就是圖書借閱者和圖書。用這種方式構成的關系在進行修改時,會出現問題。因為一個圖書借閱者可能借閱多本書,如果某個圖書借閱者的某個字段(如聯(lián)系電話)出現變更,它所借閱的圖書記錄(可能多個)也就必須變化,這是不好的。因此數據用兩個關系表示更好?,F在如果某圖書借閱者改變了它的聯(lián)系電話,只有關系(表)user的對應行需要改變。當然,要想產生一個,顯示
20、圖書名稱及其借閱者聯(lián)系電話的報表,就需要將這兩個表的行結合起來。結果表明,將關系分別存儲,在生成報表的時候將它們結合起來,比把它們存儲在一個合成的表中更好。</p><p> user(借書證號,姓名,性別,身份編號,身份證,聯(lián)系電話,)</p><p> book(圖書編號,圖書名稱,圖書類別,作者,出版社,出版日期,備注,價格,數量)</p><p><
21、;b> 元數據</b></p><p> 數據庫是自描述的,這就意味著它自身包含了它的結構的描述,這種結構的描述稱作元數據。因為DBMS產品是用來存儲和操縱表的,所以大多數產品把元數據以表的形式存儲,有時稱作系統(tǒng)表。這些系統(tǒng)表存儲了數據庫中表的情況,指出每一個表中有多少列,那一列是主關鍵字,每一列的數據類型的描述,它也存儲索引、關鍵字、規(guī)則和數據庫結構的其他部分。</p>&l
22、t;p> 在表中存儲元數據不僅對DBMS是有效的,對用戶也是方便的,因為他們可以使用與查詢用戶數據同樣的查詢工具來查詢元數據。本文第二章所介紹的SQL語言可以同時用于元數據和用戶數據。</p><p><b> 索引</b></p><p> 第三種類型的數據改進了數據庫的性能和可訪問性,這種數據經常稱作開銷數據,盡管有時也采用其他類型的數據結構,如鏈表,
23、但它主要還是索引。索引可以用來排序和快速訪問數據。下面以本人的圖書管理信息系統(tǒng)中的book表為例來說明。</p><p> 假定數據在磁盤上是按’圖書編號’的遞增順序排列的,用戶想打印一個按’圖書名稱’排序的圖書數據報表。為此,所有的數據都需要從源表中提取出來并排序,除非表很小,否則這是一個很費時的過程?;蛘?,可以在‘圖書名稱’字段上創(chuàng)建一個索引,該索引的條目按照‘圖書名稱’排序,這樣,該索引的條目可以讀出來,
24、并用來按順序訪問book數據。</p><p> 索引用于快速訪問數據。例如,一個用戶只想訪問book表中‘圖書類別’值為‘01’的那些學生。如果沒有索引,則必須搜索整個源表;但有了索引之后,可以找到索引條目,并使用它來挑選所有合適的行。</p><p> 索引對排序和查找是有幫助的,但要付出代價。book表中的行每次改變時,索引也必須改變,這意味著索引并非隨意的,應該在真正需要時保存
25、。</p><p><b> 應用元數據</b></p><p> 存儲在數據庫中的第四種數據是應用元數據,它用來存儲用戶窗體、報表、查詢和其他形式的查詢組件。并非所有的DBMS都支持應用組件,支持組件的DBMS也不一定把全部組件的結構作為應用元數據存儲在數據庫中。然而,大多數現代的DBMS產品存儲這種數據作為數據庫的一部分。一般來說,數據庫開發(fā)人員和用戶都不直接
26、訪問應用元數據,想反,他們通過DBMS中的工具來處理這些數據。</p><p> MS SQL Server2000中就支持窗體、存儲過程等應用元數據。</p><p><b> 數據庫管理系統(tǒng)</b></p><p> 數據庫管理系統(tǒng)(DBMS)是指數據庫系統(tǒng)中管理數據的軟件系統(tǒng)。DBMS是數據庫系統(tǒng)的核心組成部分。對數據庫的一切操作,
27、包括定義、更新及各種控制,都是通過DBMS進行的。DBMS總是基于某種數據模型,可以把DBMS看成是某種數據模型在計算機系統(tǒng)上的具體實現。根據數據模型的不同,DBMS可以分成層次型、網狀型、關系型、面向對象型等。MS SQL Server2000就是一種關系型數據庫管理系統(tǒng)。</p><p> 關系模型。關系模型主要是用二維表格結構表達實體集,用外鍵表示實體間聯(lián)系。關系模型是由若干個關系模式組成的集合。關系模式
28、相當于前面提到的記錄類型,它的實例稱為關系,每個關系實際上是一張二維表格。</p><p> 關系模型和層次、網狀模型的最大判別是用關鍵碼而不是用指針導航數據,表格簡單用戶易懂,編程時并不涉及存儲結構,訪問技術等細節(jié)。關系模型是數學化模型。SQL語言是關系數據庫的標準化語言,已得到了廣泛的應用。DBMS的特點和功能可以分為三個子系統(tǒng):設計工具子系統(tǒng)、運行子系統(tǒng)和DBMS引擎。</p><p&
29、gt; 設計子系統(tǒng)有一個方便數據庫及其應用創(chuàng)建的工具集。它典型地包含產生表、窗體、查詢和報表的工具。DBMS產品還提供編程語言和對編程語言的接口。</p><p> 運行子系統(tǒng)處理用設計子系統(tǒng)開發(fā)的應用組件。它所包含的運行處理器用來處理窗體和數據庫的數據交互,以及回答查詢和打印報表等。</p><p> DBMS引擎從其他兩個組件接受請求,并把它們翻譯成對操作系統(tǒng)的命令,以便讀寫物理
30、介質上的數據。DBMS引擎還涉及事務管理、鎖、備份和恢復。</p><p><b> 創(chuàng)建數據庫</b></p><p> 數據庫模式定義了數據庫的結構、表、關系、域和業(yè)務規(guī)則。數據庫模式是一種設計,數據庫和應用正是建立在此基礎上的。</p><p> 域是一列可能擁有的值的集合。必須為每一個表的每一列確定域。除了數據的物理格式外,還需要
31、確定是否有些域對表來說是唯一的。</p><p> 數據庫模式的最后一個要素是業(yè)務規(guī)則,它是對需要反映在數據庫和數據庫應用程序中的業(yè)務活動的約束。業(yè)務規(guī)則是模式的一個重要部分,因為他們指定了無論什么數據變化到達DBMS引擎,允許的數據值必須滿足的約束。不管無效的數據變化請求是來自窗體的用戶、查詢/修改請求還是應用程序,DBMS都應該拒絕。</p><p> 遺憾的是,不同的DBMS產品
32、用不同的方法實施業(yè)務規(guī)則。在某些情況下,DBMS產品不具備實施必要業(yè)務規(guī)則的能力,必須以代碼形式把它們編入應用程序。</p><p><b> 圖書管理系統(tǒng)</b></p><p> 當今時代是飛速發(fā)展的信息時代。在各行各業(yè)中離不開信息處理,這正是計算機被廣泛應用于信息管理系統(tǒng)的環(huán)境。計算機的最大好處在于利用它能夠進行信息管理。使用計算機進行信息控制,不僅提高了工
33、作效率,而且大大的提高了其安全性。</p><p> 尤其對于復雜的信息管理,計算機能夠充分發(fā)揮它的優(yōu)越性。計算機進行信息管理與信息管理系統(tǒng)的開發(fā)密切相關,系統(tǒng)的開發(fā)是系統(tǒng)管理的前提。本系統(tǒng)就是為了管理好圖書館信息而設計的。</p><p> 圖書館作為一種信息資源的集散地,圖書和用戶借閱資料繁多,包含很多的信息數據的管理,現今,有很多的圖書館都是初步開始使用,甚至尚未使用計算機進行信
34、息管理。根據調查得知,他們以前對信息管理的主要方式是基于文本、表格等紙介質的手工處理,對于圖書借閱情況(如借書天數、超過限定借書時間的天數)的統(tǒng)計和核實等往往采用對借書卡的人工檢查進行,對借閱者的借閱權限、以及借閱天數等用人工計算、手抄進行。數據信息處理工作量大,容易出錯;由于數據繁多,容易丟失,且不易查找。總的來說,缺乏系統(tǒng),規(guī)范的信息管理手段。盡管有的圖書館有計算機,但是尚未用于信息管理,沒有發(fā)揮它的效力,資源閑置比較突出,這就是管
35、理信息系統(tǒng)的開發(fā)的基本環(huán)境。</p><p> 數據處理手工操作,工作量大,出錯率高,出錯后不易更改。圖書館采取手工方式對圖書借閱情況進行人工管理,由于信息比較多,圖書借閱信息的管理工作混亂而又復雜;一般借閱情況是記錄在借書證上,圖書的數目和內容記錄在文件中,圖書館的工作人員和管理員也只是當時對它比較清楚,時間一長,如再要進行查詢,就得在眾多的資料中翻閱、查找了,造成查詢費時、費力。如要對很長時間以前的圖書進行
36、更改就更加困難了。</p><p> 基于這些問題,我認為有必要建立一個圖書管理系統(tǒng),使圖書管理工作規(guī)范化,系統(tǒng)化,程序化,避免圖書管理的隨意性,提高信息處理的速度和準確性,能夠及時、準確、有效的查詢和修改圖書情況。</p><p><b> 系統(tǒng)所做工作</b></p><p> 1) 了解應用開發(fā)工具的現狀</p>&l
37、t;p> 2) DelPHi6.0編程基礎</p><p> 3) MS SQL Server基礎</p><p> 4) 設計數據庫;設計界面</p><p> 5) 開發(fā)數據庫。數據庫實現的一些功能有</p><p> l 數據和數據說明的醒目顯示;</p><p> l 多條件的查詢、多條記錄的
38、檢索、模糊查詢;</p><p> l 數據文件某種存儲格式導入數據窗體,經過數據完整性校驗存入數據庫;</p><p> l 數據庫安全性的設計;</p><p> l 數據庫的設計、數據接口、界面的設計。</p><p><b> 數據庫理論基礎</b></p><p> 一個成功的
39、信息管理系統(tǒng),是建立在許多條件之上的,而數據庫是其中一個非常重要的條件和關鍵技術。</p><p> 信息管理系統(tǒng)所涉及的數據庫設計分五個步驟:數據庫需求分析、概念設計、邏輯設計、物理設計與加載測試。</p><p> ?。?) 數據庫需求分析的任務是將業(yè)務管理單證流化為數據流,劃分主題之間的邊界,繪制出DFD圖,并完成相應的數據字典。</p><p> ?。?)
40、 概念設計的任務是從DFD出發(fā),繪制出本主題的實體-關系圖,并列出各個實體與關系的綱要表。</p><p> ?。?) 邏輯設計的任務是從E-R圖與對應的綱要表出發(fā),確定各個實體及關系的表名屬性。</p><p> ?。?) 物理設計的任務是確定所有屬性的類型、寬度與取值范圍,設計出基本表的主鍵,將所有的表名與字段名英文化(現在很多軟件能支持中文字段,如MS SQL Server,我就是用
41、的中文字段名),實現物理建庫,完成數據庫物理設計字典。</p><p> ?。?) 加載測試工作貫穿于程序測試工作的全過程,整個錄入、修改、查詢、處理工作均可視為對數據庫的加載測試工作。</p><p> 要設計出一個好的信息管理系統(tǒng)數據庫,除滿足系統(tǒng)所要求的功能外,還必須遵守下列原則:</p><p> 1 基本表的個數越少越好。</p><
42、;p> 2 主鍵的個數越少越好。鍵是表間連接的工具,主鍵越少,表間的連接就越簡單。</p><p> 3 字段的個數越少越好。</p><p> 4 所有基本表的設計均應盡量符合第三范式。</p><p> 數據庫的設計中,如何處理多對多的關系和如何設計主鍵,是兩個有著較大難度、需要重點考慮的問題。下面我們著重從SQL應用、數據庫設計范式和查詢優(yōu)化等方
43、面來分析本課題的系統(tǒng)關鍵技術和實現難點并加以解決。</p><p> 數據庫系統(tǒng)設計及范式分析</p><p> 信息系統(tǒng)的主要任務是通過大量的數據獲得管理所需要的信息,這就必須存儲和管理大量的數據。因此建立一個良好的數據組織結構和數據庫,使整個系統(tǒng)都可以迅速、方便、準確地調用和管理所需的數據,是衡量信息系統(tǒng)開發(fā)工作好壞的主要指標之一。</p><p><
44、b> 數據庫系統(tǒng)設計</b></p><p> 數據庫設計主要是進行數據庫的邏輯設計,即將數據按一定的分類、分組系統(tǒng)和邏輯層次組織起來,是面向用戶的。數據庫設計時需要綜合企業(yè)各個部門的存檔數據和數據需求,分析各個數據之間的關系,按照DBMS提供的功能和描述工具,設計出規(guī)模適當、正確反映數據關系、數據冗余少、存取效率高、能滿足多種查詢要求的數據模型。</p><p>
45、 數據庫設計的步驟是:</p><p> (1) 數據庫結構定義:目前的數據庫管理系統(tǒng)(DBMS)有的是支持聯(lián)機事務處理CLTP(負責對事務數據進行采集、處理、存儲)的操作型DBMS,有的可支持數據倉庫、有聯(lián)機分析處理CLAP(指為支持決策的制定對數據的一種加工操作)功能的大型DBMS,有的數據庫是關系型的、有的可支持面向對象數據庫。針對選擇的DBMS,進行數據庫結構定義。</p><p&g
46、t; (2) 數據表定義:數據表定義指定義數據庫中數據表的結構,數據表的邏輯結構包括:屬性名稱、類型、表示形式、缺省值、校驗規(guī)則、是否關鍵字、可否為空等。關系型數據庫要盡量按關系規(guī)范化要求進行數據庫設計,但為使效率高,規(guī)范化程度應根據應用環(huán)境和條件來決定。數據表設計不僅要滿足數據存儲的要求,還要增加一些如反映有關信息、操作責任、中間數據的字段或臨時數據表。</p><p> (3) 存儲設備和存儲空間組織:確
47、定數據的存放地點、存儲路徑、存儲設備等,備份方案,對多版本如何保證一致性和數據的完整性。</p><p> ?。?) 數據使用權限設置:針對用戶的不同使用要求,確定數據的用戶使用權限,確保數據安全。</p><p> ?。?) 數據字典設計:用數據字典描述數據庫的設計,便于維護和修改。</p><p> 為了更好地組織數據和設計出實際應用數據庫,應該注意如下問題:
48、</p><p> 規(guī)范化地重組數據結構:對數據進行規(guī)范化表達,這在后面將會具體討論。</p><p> 關系數據結構的建立:在進行了數據基本結構的規(guī)范化重組后,還必須建立整體數據的關系結構。這一步設計完成后數據庫和數據結構設計工作基本完成,只待系統(tǒng)實現時將數據分析和數據字典的內容代入到所設計的數據整體關系結構中,一個規(guī)范化數據庫系統(tǒng)結構就建立起來了。 </p><
49、p> 建立關系數據結構涉及三方面內容:確定關聯(lián)的關鍵指標項并建立關聯(lián)表;確定單一的父系記錄結構;建立整個數據庫的關系結構。 </p><p> ?。?)鏈接關系的確定 </p><p> 在進行了上述數據規(guī)范化重組后,已經可以確保每一個基本數據表(我們簡稱為表)是規(guī)范的,但是這些單獨的表并不能完整地反映事物,通常需要通過指標體系整體指標數據才能完整全面地反映問題。也就是說在這些基
50、本表的各宇段中,所存儲的是同一事物不同側面的屬性。那么計算機系統(tǒng)如何能知道哪些表中的哪些記錄應與其它表中的哪些記錄相對應,它們表示的是同一個事物呢?這就需要在設計數據結構時將這種各表之間的數據記錄關系確定下來。這種表與表之間的數據關系一般都是通過主或輔關鍵詞之間的連接來實現的。因為在每個表中只有主關鍵詞才能唯一地標識表中的這一個記錄值(因為根據第三范式的要求,表中其它數據字段函數都依賴于主關鍵詞),所以將表通過關鍵詞連接就能夠唯一地標識
51、出某一事物不同屬性在不同表中的存放位置。 </p><p> ?。?)確定單一的父子關系結構 </p><p> 所謂確定單一的父系關系結構就是要在所建立的各種表中消除多對多(以下用M:N來表示)的現象,即設法使得所有表中記錄之間的關系呈樹狀結構(只能由一個主干發(fā)出若干條分支,而不能有若干條主干交錯發(fā)出若干條分支狀況)。所謂的“父系”就是指表的上一級關系表。消除多對多關系可以借助于E-R
52、圖的方法來解決,也可以在系統(tǒng)分析時予以注意,避免這種情況的發(fā)生。 </p><p> 消除這種M:N情況的辦法也很簡單,只需在二表之間增加一個表,則原來M:N的關系就改成了M:1,1:N的關系了。</p><p> 確定數據資源的安全保密屬性:</p><p> 一般DBMS都提供給我們自己定義數據安全保密性的功能。系統(tǒng)所提供的安全保密功能一般有8個等級(0-
53、7級),4種不同方式(只讀、只寫、刪除、修改),而且允許用戶利用這8個等級的4種方式對每一個表自由地進行定義。 </p><p> 定義安全保密性的方法一般有如下幾種: </p><p> a.原則上所有文件都定義為4級,個別優(yōu)先級特別高的辦公室(終端或微機的入網賬號)可定義高于4級的級別,反之則定義為低于4的級別。 </p><p> b.統(tǒng)計文件(表)和數
54、據錄入文件一般只對本工作站定義為只寫方式,對其它工作站則定義為只讀方式。 </p><p> c.財務等保密文件一般只對中工作站(如財務科等)定義為可寫、可改、可刪除方式,對其它工作站則定義為只讀方式,而且不是每個人都能讀,只有級別相同和高級別者才能讀。</p><p> 數據庫設計范式分析 </p><p> 建立起一個良好的數據指標體系,是建立數據結構和數
55、據庫的最重要的一環(huán)。一個良好的數據指標體系是建立DB的必要條件,但不是充分條件。我們完全可以認為所建指標體系中的一個指標類就是關系數據庫中的一個基本表,而這個指標類下面的一個個具體指標就是這個基本表中的一個字段。但如果直接按照這種方式建庫顯然還不能算最佳。對于指標體系中數據的結構在建庫前還必須進行規(guī)范化的重新組織。 </p><p><b> SQL語言介紹</b></p>
56、<p><b> SQL基礎</b></p><p> SQL(Structured Query Language,結構查詢語言)是一個功能強大的數據庫語言。SQL通常使用于數據庫的通訊。ANSI(美國國家標準學會)聲稱,SQL是關系數據庫管理系統(tǒng)的標準語言。SQL語句通常用于完成一些數據庫的操作任務,比如在數據庫中更新數據,或者從數據庫中檢索數據。使用SQL的常見關系數據庫管
57、理系統(tǒng)有:Oracle、 Sybase、 Microsoft SQL Server、 Access、 Ingres等等。雖然絕大多數的數據庫系統(tǒng)使用SQL,但是它們同樣有它們自立另外的專有擴展功能用于它們的系統(tǒng)。但是,標準的SQL命令,比如"Select"、 "Insert"、 "Update"、 "Delete"、 "Create"和
58、"Drop"常常被用于完成絕大多數數據庫的操作。MS SQL Server 就是用的Transact- SQL。</p><p> SQL語言有著非常突出的優(yōu)點,主要是:</p><p><b> 1. 非過程化語言</b></p><p><b> 2. 統(tǒng)一的語言</b></p>
59、<p> 3. 是所有關系數據庫的公共語言</p><p> 非過程化語言:SQL是一個非過程化的語言,因為它一次處理一個記錄,對數據提供自動導航。SQL允許用戶在高層的數據結構上工作,而不對單個記錄進行操作,可操作記錄集,所有SQL 語句接受集合作為輸入,返回集合作為輸出。SQL的集合特性允許一條SQL語句的結果作為另一條SQL語句的輸入。</p><p> SQL不要
60、求用戶指定對數據的存放方法, 這種特性使用戶更易集中精力于要得到的結果;所有SQL語句使用查詢優(yōu)化器,它是RDBMS的一部分,由它決定對指定數據存取的最快速度的手段,查詢優(yōu)化器知道存在什么索引,在哪兒使用索引合適,而用戶則從不需要知道表是否有索引、有什么類型的索引。</p><p> 統(tǒng)一的語言:SQL可用于所有用戶的DB活動模型,包括系統(tǒng)管理員、數據庫管理員、 應用程序員、決策支持系統(tǒng)人員及許多其它類型的終端
61、用戶。</p><p> SQL為許多任務提供了命令,其中包括:</p><p><b> 1.查詢數據</b></p><p> 2.在表中插入、修改和刪除記錄</p><p> 3.建立、修改和刪除數據對象 </p><p> 4.控制對數據和數據對象的存取</p>&
62、lt;p> 5.保證數據庫一致性和完整性</p><p> 以前的數據庫管理系統(tǒng)為上述各類操作提供單獨的語言,而SQL 將全部任務統(tǒng)一在一種語言中。</p><p> 所有關系數據庫的公共語言:由于所有主要的關系數據庫管理系統(tǒng)都支持SQL語言,用戶可將使用SQL的技能從一個RDBMS(關系數據庫管理系統(tǒng))轉到另一個,所有用SQL編寫的程序都是可以移植的。</p>
63、<p><b> SQL語句</b></p><p> SQL功能強大,是一種完備的數據處理語言,不僅用于數據庫查詢,而且用于數據庫中的數據修改和更新,概括起來,它可以分成以下幾組:</p><p> DML(Data Manipulation Language,數據操作語言):用于檢索或者修改數據; </p><p> DD
64、L(Data Definition Language,數據定義語言): 用于定義數據的結構,比如 創(chuàng)建、修改或者刪除數據庫對象; </p><p> DCL(Data Control Language,數據控制語言):用于定義數據庫用戶的權限。</p><p> DML組可以細分為以下的幾個語句:</p><p> SELECT:用于檢索數據;</p&g
65、t;<p> INSERT:用于增加數據到數據庫;</p><p> UPDATE:用于從數據庫中修改現存的數據;</p><p> DELETE:用于從數據庫中刪除數據。</p><p> DDL語句可以用于創(chuàng)建用戶和重建數據庫對象。下面是DDL命令:</p><p> CREATE TABLE,ALTER TABL
66、E,DROP TABLE,CREATE INDEX,DROP INDEX</p><p> 下面是一個簡單SQL語句的例子:</p><p> 我們使用SQL語句來從Book中檢索‘借書證號’為‘000001’的借閱者姓名:</p><p> SELECT 姓名 FROM Book WHERE 借書證號 = ‘000001’</p>&l
67、t;p> 2.2.2.1 DDL與DML</p><p> 數據定義語言DDL:它是用來創(chuàng)建和修改數據庫結構的一種語句,包括 Create、Alter和Drop 語句。 </p><p> 數據操作語言DML:包括數據查詢與數據更新。數據查詢主要是由Select語句完成,這一點不再贅述。而數據更新所造成的風險大大超過數據查詢。數據庫管理系統(tǒng)必須在更改期內保護所存儲的數據的一致性
68、,確保有效的數據進入數據庫,數據庫必須保持一致性,DBMS還必須協(xié)調多用戶的并行更新,以確保用戶和它們的更改不至于影響其它用戶的作業(yè)。</p><p> 用于修改數據庫內容的 SQL 語句主要有以下三個: </p><p> (1) Insert,向一個表中加入新的數據行 </p><p> (2) Delete,從一個表中刪除數據行 </p>
69、<p> (3) Update,更改數據庫中已經存在的數據 </p><p> Insert標準語法: </p><p> INSERT INTO table_name (col1, col2...) VALUES(value1, value2...)</p><p> 下例要將借書證號為‘000001’作為一個新的借書情況加入借書情況表
70、OWNER中</p><p> Insert Into</p><p> owner (借書證號,圖書編號,借書日期) </p><p> values (‘000001’,‘00000001’,‘2002-9-12’)</p><p> Insert 語句還可以將多行數據添加到目標表中去,在這種形式的 Insert 語句中,新行的數
71、據值不是在語句正文中明確地指定的,而是語句中指定的一個數據庫查詢。添加的值來自數據庫自身的行,在某些特定的狀態(tài)下,這是非常有用的。多行 Insert 語句為拷貝數據提供了一種緊湊而高效的方法,但我在自已做的圖書管理系統(tǒng)中沒有使用這種方法,我在系統(tǒng)中是使用循環(huán)依照上面的用法來完成多個記錄的插入。 </p><p> Update語句用于更新單表中選定行的一列或多列的值。要更新的目標表在語句中定義,Set子句則指定
72、要更新哪些列并計算它們的值。Update語句總是包含Where語句,而且Update語句比較危險,所以您必須明確地認識到Where語句的重要性,Where語句被用來指定需要更新的行。</p><p><b> 標準語法:</b></p><p> UPDATE table_name</p><p> SET columnname1 = v
73、alue1</p><p> [, columname2 = value2]...</p><p> WHERE search_condition</p><p> Delete 語句標準語法:</p><p> DELETE FROM tablename WHERE condition</p><p>
74、; 2.2.2.2 復雜操作實現</p><p> 在信息管理系統(tǒng)中,我們往往會遇到歸類、匯總、映射、索引、子查詢等復雜操作,相應的支持與實現如下:</p><p> u GROUP BY方法</p><p> GROUP BY子句語法為: </p><p> SELECT column1, SUM(column2)</p&g
75、t;<p> FROM "list-of-tables"</p><p> GROUP BY "column-list"; </p><p> 這個GROUP BY子句將集中所有的行在一起,它包含了指定列的數據以及允許合計函數來計算一個或者多個列。</p><p> 在本人的系統(tǒng)中在顯示數據時用到了此語句
76、來對查詢所得的內容排序然后再顯示。</p><p> u 組合條件和布爾運算符</p><p> 以下的SQL語句中就含有組合條件:</p><p> SELECT column1, SUM(column2)</p><p> FROM "list-of-tables"</p><p>
77、WHERE "condition1" AND "condition2"; </p><p><b> 下面是一個示例:</b></p><p> SELECT 身份描述</p><p> FROM ID,user</p><p> WHERE ID.身份編號=USER.身份
78、編號 and user.借書證號=’000001’; </p><p> 這條SQL語句是從user、id表中查找借閱證號為000001的借閱者的身份描述,第三條語句中如果其中有一個條件為假,那么就什么都沒有顯示。</p><p><b> u UNION子句</b></p><p> 有些時候,需要一起瀏覽多個查詢的結果、組合它們的輸出
79、,我們可以使用UNION關鍵字。 </p><p><b> 應用系統(tǒng)開發(fā)工具</b></p><p> Delphi6.0 VCL組件的體系結構</p><p> Delphi類可以粗略地分成兩部分:一部分是組件類,這些組件類通常以某種方式出現在組件面板上,當用戶從組件面板上點取一個類的圖標后,在程序中就自動生成了該類的對象(非可視組件
80、除外);另一部分是功能類,這此功能類的對象通常出現在程序代碼中,起著不可代替的作用,但是這些功能類在組件面板上是找不到的。在Delphi中,每一個類的祖先都是Tobject類,整個類的層次結構就像一棵倒掛的樹,在最頂層的樹根即為Tobject類。這樣,按照面向對象編程的基本思想,就使得用戶可用Tobject類這個類型代替任何其它類的數據類型。實際上在Delphi的類庫中,Tobject類派生出了為數相當眾多的子類,它們形成了一個龐大的體
81、系,通常情況下,如果不自行開發(fā)組件,就不必了解整個類的體系結構,只用到類層次樹的葉結點就足夠了。</p><p> 凡是做過程序開發(fā)的人都知道從來沒有單純的數據應用程序,也就是說,數據庫應用程序必須和用戶界面(可以是圖形界面,也可以是命令接口)元素相結合,只講界面或只講數據庫本身都構不成數據庫應用程序,因而用Delphi6.0開發(fā)數據庫應用程序就隱含著界面開發(fā)。</p><p> 組件
82、在Delphi程序的開發(fā)中是最顯眼的角色。我們知道,在編寫程序時一般都開始于在組件面板上選擇組件并定義組件間的相互作用。但也有一些組件不在組件面板上,例如Tform和Tapplication(典型的非可視組件)。組件是Tcomponents派生出來的子類,可以流的形式存放在DFM文件中,具有事件和Publish屬性。</p><p> 窗口組件類是窗口化的可視化組件類,在Delphi的類庫中占有最大的份額。在實
83、際編程中,窗口組件類的對象都有句柄,可以接受輸入焦點和包含其它組件。</p><p> 圖形組件與窗口組件并列,是另一大類組件。圖形組件不是基于窗口的,因而不能有窗口句柄,不能接受輸入焦點和包含其它組件。在實際編程中,它們必須寄生于它們的宿主——窗口組件類的對象,由它們的擁有者負責其顯示,而且它們還能觸發(fā)一些和鼠標活動相關的事件。圖形控件最典型的例子是Tlabel和TspeedButton??梢钥闯鰣D形組件的功
84、能很弱,圖形組件的用處何在呢?其實使用圖形組件的最大好處在于節(jié)省資源,正是因為它們的功能較弱,所以使用的系統(tǒng)資源就要少。在一個應用程序中,如果能在不影響其功能的前提下合理大量地使用圖形組件,將會大減少程序對系統(tǒng)資源的消耗。</p><p> 非可視組件是與可視組件相并列的另一類組件,非可視組件在程序運行中是不可見的(除各種對話框組件之外,事實上有人認為對話框組件不能歸入非可視組件,應該是另一種介于可視與非可視之
85、間的組件)。</p><p> 最后要說明一下,常說的控件實際上是一種組件。也就是說組件這個概念要大于控件,控件在內涵上包含于組件中??丶蒞indows系列操作系統(tǒng)提出并使用,而組件是Borland和其它廠商在對Windows控件做了必要的擴展之后提出來的概念,它們是在不同時期由不同的廠商提出的概念。 </p><p><b> 數據庫組件介紹</b><
86、;/p><p> 用Delphi6開發(fā)數據庫應用,重點是和各種數據庫組件打交道,能和數據庫掛鉤的組件對象有5種,它們是:Session(數據庫會話)、Database(數據庫)、Dataset(數據集)、DataSource(數據源)、Data control(數據控制組件,也叫data-controls即數據感知組件)。其中前面4種統(tǒng)稱為數據訪問(Data Access) ADO組件 Delphi6.0包含了可以
87、用來訪問Microsoft公司的ActiveX Data Objects(ADO)格式數據庫的組件。ADO是Micrsoft公司關于各種類型數據的高等界面,后來逐漸演變成滿足所有數據訪問需要的完整解決辦法。ADO的對象模型是所有數據訪問接口對象模型中最簡單的一種。Microsoft公司用來訪問ADO數據的應用程序界面技術是OLE DB。OLE DB是一種底層編程接口,用來訪問許多不同類型的數據源,其中包括消息、文件系統(tǒng)以及其他一些非傳
88、統(tǒng)的數據源。OLE DB是一個由Component Object Model(COM)接口組成的集合,用來隱藏創(chuàng)建數據訪問服務過程中的細節(jié)。OLEDB提供了訪問</p><p> Delphi的ADO組件無需依靠BDE而是使用ADO技術,提供了可以通過數據控制組件訪問數據的新方法。唯一的要求是在使用ADO組件時必須運行ADO/OLE-DB。ADO組件的使用使得DELPHI在訪問數據的類型和采用的技術方面都有了很
89、大的突破。</p><p> 數據模塊設計窗口: 數據模塊設計窗口是用來設計和維護數據模塊的。數據模塊設計窗口中包含了所有以.DTI作為文件擴展名的Data Diagram文件的信息。DTI文件在編譯時不起任何作用。</p><p> SQL語言在Delphi中的應用</p><p> 在Delphi中使用SQL語言非常方便,一般來說,都是通過Tquery或
90、TADOquery組件來使用SQL語言的。可以在Tquery或TADOquery組件的SQL屬性中設置SQL語句。設計程序時,在該組件的屬性對話框中選擇SQL屬性,單擊帶省略號的按鈕,就可以打開String List Editor對話框,然后我們就可以在對話框中添加SQL語句。還可以使用Delphi的SQL Builder來自動生成SQL語句,這樣可以避免手工編寫SQL而可能造成的語法錯誤。</p><p>
91、靜態(tài)SQL語句在程序設計時便已固定下來,它不包含任何參數和變量。</p><p> 動態(tài)SQL語句,也被稱作參數化的語句,在其中間包含著表示字段名或表名的參數,例如下面的語句是一條動態(tài)SQL語句: </p><p> Select * From Book Where 圖書編號 =:bookCode; </p><p> 其中的變量bookCode便是一
92、個參數變量,它由一個冒號引導,在程序運行過程中,必須要為該參數賦值,該條SQL語句才能正確執(zhí)行,每次運行應用程序時可以為該參數變量賦予不同的值。為參數賦值有三種方法:</p><p> ?、俑鶕翟赟QL語句中出現的順序,設置TADOQuery組件的parameters屬性值為參數賦值。</p><p> ②直接根據SQL語句中各參數的名字,調用ParamByName方法來為各參數賦值
93、。</p><p> ?、蹖ADOQuery組件的DataSource屬性設置為另一個數據源,這樣將另一個數據源中與當前TADOQuery組件的SQL語句中的參數名相匹配的字段值賦給其對應的參數。利用這種方法也能實現所謂的連接查詢,創(chuàng)建主要—明細型數據庫應用。</p><p> 在使用動態(tài)SQL語句編程時,常常用到一個很重要的方法Prepare,調用Prepare 方法之后,Delph
94、i會將帶參數的SQL語句傳送給與其對應的數據庫引擎,對動態(tài)SQL語句進行語法分析和優(yōu)化。雖然在用動態(tài)SQL語句編程時,調用Prepare方法并不是必須的,但是調用Prepare方法后,會極大地提高動態(tài)SQL 語句的執(zhí)行性能,特別是當要反復多次執(zhí)行同一條動態(tài)SQL語句時,其優(yōu)越性會更加明顯。 </p><p> 如果在應用程序中執(zhí)行一條SQL語句之前并沒有顯式地調用Prepare方法,每次在執(zhí)行SQL 語句時,D
95、elphi會隱含地調用Prepare方法以準備這個查詢。</p><p> TadoQuery部件還有一個Prepare屬性,這是一個布爾型屬性,當其屬性值為True時, 表明該查詢已被準備好了( SQL 語句已被傳送到數據庫引擎中 ) , 當我們使用參數編輯器Parameters Editor來為動態(tài)SQL語句中的參數賦值時,當設置完相應的參數值并退出參數編輯器時,Delphi會隱含地調用Prepare方法以
96、準備好查詢。</p><p> 當SQL語句執(zhí)行完之后,要想準備下一個查詢,首先必須調用Close方法,然后才能調用Prepare方法準備下一個查詢。一般來說,在一個應用程序中應該調用一次Prepare方法,常常在窗體的OnCreate事件處理過程中調用Prepare方法, 然后用上述介紹的方法為參數賦值,最后調用Open方法或ExecSQL方法執(zhí)行SQL語句,以完成查詢。</p><p&g
97、t; 當然在調用Prepare方法準備好一個查詢時,會消耗一些數據庫資源,因而每當一個查詢執(zhí)行完畢之后,要養(yǎng)成調用UnPrepare方法以撤消查詢的好習慣。在運行程序過程中,通過程序改變TQuery或TADOquery部件的SQL屬性值時,Delphi會自動地調用Close方法和UnPrepare 方法,以撤消查詢。</p><p> 在程序運行過程中,要想設置Tquery或TADOquery部件的SQL屬性
98、,必須首先調用Close方法,關閉TQuery或TADOquery部件,然后再調用Clear方法清除SQL屬性中現存的SQL命令語句, 最后再調用Add方法為SQL屬性設置新的SQL命令語句。例如: </p><p> datamodule4.adoquery2.close;</p><p> datamodule4.adoquery2.sql.clear;</p>&l
99、t;p> datamodule4.adoquery2.sql.add('SELECT 借書證號,密碼 FROM [user] </p><p> WHERE (借書證號 = :tt)');</p><p> datamodule4.adoquery2.parameters[0].value:=username;</p><p> dat
100、amodule4.adoquery2.open; </p><p> 在為TQuery或TADOquery部件設置SQL屬性時調用Close方法總是很安全的,如果TQuery或TADOquery部件已經被關閉了,調用Close方法時不會產生任何影響。在應用程序中為SQL屬性設置新的SQL 命令語句時,必須要調用Clear方法以清除SQL屬性中現存的SQL命令語句,如果不調用Clear方法,便調用Add方法向SQ
101、L屬性中設置SQL命令語句,那么新設置的SQL命令語句會追加在現存SQL命令語句后面, 在程序運行時常常會出現出乎意料的查詢結果甚至程序無法運行下去。</p><p> 在這里要特別注意的,一般情況下TQuery或TADOquery部件的SQL屬性只能包含一條完整的SQL語句,它不允許被設置成多條SQL語句。當然有些數據庫服務器也支持在TQuery或TADOquery部件的SQL屬性中設置多條SQL語句,只要數
102、據庫服務器允許這樣,我們在編程時可以為 SQL 屬性設置多條SQL語句。</p><p> 在為TQuery或TADOquery部件設置完SQL屬性的屬性值之后,也即編寫好適當的SQL程序之后,可以有多種方式來執(zhí)行SQL程序。</p><p> 在設計過程中,設置完TQuery或TADOquery部件的SQL屬性之后將其Active屬性的值置為True,這樣便可以執(zhí)行SQL屬性中的SQ
103、L程序,如果應用中有與TQuery或TADOquery部件相連的數據瀏覽部件( 如TDDGrid TDBEdit等)那么在這些數據瀏覽部件中會顯示SQL程序的執(zhí)行結果。</p><p> 在應用程序運行過程中,通過程序調用TQuery或TADOquery組件的Open方法或ExecSQL 方法可以執(zhí)行其SQL屬性中的SQL程序。Open方法和ExecSQL方法是不一樣的。Open方法只能用來執(zhí)行SQL語言的查詢
104、語句(Select命令), 并返回一個查詢結果集,而ExecSQL方法還可以用來執(zhí)行其它常用的SQL語句(如INSERT, UPDATE, DELETE等命令),例如:</p><p> Query1.Open (這樣會返回一個查詢結果集)</p><p> 如果調用Open方法,而沒有查詢結果時,會出錯。此時應該調用ExecSQL </p><p> 方法來
105、代替Open方法。如:</p><p> Query1.ExecSQL (沒有返回結果)</p><p> 當然在設計應用程序時,程序設計人員是無法確定TQuery或TADOquery組件中的SQL 語句是否會返回一個查詢結果的。對于這種情況應當用Try…Except模塊來設計程序。在 Try 部分調用Open方法,而在Except部分調用ExceSQL方法,這樣才能保證程序的正確運行
106、。</p><p><b> 例如: </b></p><p><b> Try</b></p><p> Query1.Open</p><p><b> Except</b></p><p> Query1.ExecSQL</p>
107、;<p><b> End</b></p><p> 通過Tquery或TADOquery組件可以獲得兩種類型的數據:</p><p><b> u “活動”的數據</b></p><p> 這種數據就跟通過TTable部件獲得的數據一樣,用戶可以通過數據瀏覽部件來編輯修改這些數據,并且當調用Post
108、方法或當焦點離開當前的數據瀏覽部件時,用戶對數據的修改自動地被寫回到數據庫中。</p><p> u 非活動的數據(只讀數據)</p><p> 用戶通過數據瀏覽部件是不能修改其中的數據。在缺省情況下,通過TQuery部件獲得的查詢結果數據是只讀數據,要想獲得“活動”的數據,在應用程序中必須要設置Tquery或TADOquery組件的RequestLive屬性值為True,然而并不是在
109、任何情況下(通過設置RequestLive的屬值True)都可以獲得“活動”的數據的,要想獲得“活動”的數據,除了將TQuery部件的RequestLive屬性設置為True外,相應的SQL命令還要滿足以下條件。</p><p> 本地SQL語句查詢情況下,要得到可更新的數據集,SQL語句的限制為:</p><p> 1. 查詢只能涉及到一個單獨的表</p><p
110、> 2. SQL語句中不能包含ORDER BY命令</p><p> 3. SQL語句中不能含聚集運算符SUM或AVG</p><p> 4. 在Select后的字段列表中不能有計算字段</p><p> 在Select語句WHERE部分只能包含字段值與常量的比較運算,這些比較運算符是:Like, >, <, >=, <=
111、。各比較運算之間可以有并和交運算:AND和OR</p><p> 當通過SQL語句查詢數據庫服務器中的數據庫表:</p><p> 1. 查詢只能涉及到一個單獨的表</p><p> 2. SQL語句中不能包含ORDER BY命令</p><p> 3. SQL語句中不能含聚集運算符SUM或AVG運算</p><p
112、> 另外,如果是查詢Sybase數據庫中的表,那么被查詢的表中只能有一個索引。</p><p> 如果在應用程序中要求TQuery或TADOquery組件返回一個“活動”的查詢結果數據集,但是SQL 命令語句不滿足上述約束條件時,對于本地數據庫的SQL查詢,BDE只能返回只讀的數據集。對于數據庫服務器中的SQL查詢,只能返回錯誤的代碼。當Tquery或TADOquery組件返回一個“活動”的查詢結果數據
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 圖書管理系統(tǒng) 畢業(yè)設計
- 圖書管理系統(tǒng)畢業(yè)設計
- 畢業(yè)設計---圖書管理系統(tǒng)
- 圖書管理系統(tǒng)畢業(yè)設計
- 畢業(yè)設計-----圖書管理系統(tǒng)
- 畢業(yè)設計-----圖書管理系統(tǒng)
- 圖書管理系統(tǒng)畢業(yè)設計
- 畢業(yè)設計---圖書管理系統(tǒng)
- 圖書管理系統(tǒng)畢業(yè)設計
- 畢業(yè)設計----圖書管理系統(tǒng)
- 畢業(yè)設計---圖書管理系統(tǒng)
- 畢業(yè)設計-----圖書管理系統(tǒng)
- 圖書管理系統(tǒng)(畢業(yè)設計)
- 圖書管理系統(tǒng)畢業(yè)設計
- 畢業(yè)設計 圖書管理系統(tǒng)設計
- 畢業(yè)設計----圖書管理系統(tǒng)設計
- 小型圖書管理系統(tǒng)畢業(yè)設計
- 圖書管理系統(tǒng)畢業(yè)設計論文
- 畢業(yè)設計圖書管理系統(tǒng)
- 畢業(yè)設計(論文)-圖書管理系統(tǒng)
評論
0/150
提交評論