畢業(yè)論文---學生學籍管理系統(tǒng)_第1頁
已閱讀1頁,還剩40頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、<p><b>  前 言</b></p><p>  學生學籍管理系統(tǒng)是一個教育單位不可缺少的部分,它的內(nèi)容對于學校的決策者和管理者來說都至關(guān)重要,所以學生學籍管理系統(tǒng)應(yīng)該能夠為用戶提供充足的信息和快捷的查詢手段。但一直以來人們使用傳統(tǒng)人工的方式管理文件學籍,這種管理方式存在著許多缺點,如:效率低、保密性差,另外時間一長,將產(chǎn)生大量的文件和數(shù)據(jù),這對于查找、更新和維護都帶來了不

2、少的困難。 </p><p>  隨著科學技術(shù)的不斷提高,計算機科學日漸成熟,其強大的功能已為人們深刻認識,它已進入人類社會的各個領(lǐng)域并發(fā)揮著越來越重要的作用。 </p><p>  作為計算機應(yīng)用的一部分,使用計算機對學生學籍信息進行管理,具有著手工管理所無法比擬的優(yōu)點.例如:檢索迅速、查找方便、可靠性高、存儲量大、保密性好、壽命長、成本低等。這些優(yōu)點能夠極大地提高學生學籍管理的效率,也

3、是企業(yè)的科學化、正規(guī)化管理,與世界接軌的重要條件。 </p><p>  因此,開發(fā)這樣一套管理軟件成為很有必要的事情,在下面的各章中將以開發(fā)一套學生學籍管理系統(tǒng)為例,談?wù)勂溟_發(fā)過程和所涉及到的問題及解決方法。</p><p><b>  第一章 系統(tǒng)概述</b></p><p><b>  1.1 開發(fā)背景</b><

4、;/p><p>  1.1.1 當前趨勢</p><p>  現(xiàn)代教育技術(shù)特別是網(wǎng)絡(luò)與多媒體技術(shù)的發(fā)展,對學習活動產(chǎn)生了具有深遠意義的沖擊,網(wǎng)絡(luò)中的學習者必須是一個主動行為著的主體,人們可以選擇或者設(shè)計適合其學習特點的信息采集、加工與重組方式,一種個性化的學習類型。該學籍管理系統(tǒng)采用多層架構(gòu)的系統(tǒng),是真正適應(yīng)教育信息化發(fā)展三大趨勢的校園網(wǎng)絡(luò)應(yīng)用系統(tǒng),全面支持Internet功能、遠程訪問功能,

5、全部采用最先進的B/S(瀏覽器/服務(wù)器) 模式來開發(fā),支持有關(guān)學校信息交流、日常教學、教務(wù)管理等的各種應(yīng)用,提供了一個基于校園內(nèi)聯(lián)網(wǎng)中支持各種類型的學校應(yīng)用產(chǎn)品的服務(wù)平臺和開發(fā)平臺,基本目標是在學校內(nèi)部和外部建立起順暢的信息通道,讓信息技術(shù)成為推動教育生產(chǎn)力的有力工具,提高學校的管理水平和效率,同時充分利用全球的教育資源為學校的教育服務(wù),克服了目前大部分學校的校園網(wǎng)建設(shè)只起到宣傳作用的通病。</p><p>  

6、1.1.2 用計算機管理學生學籍的意義 </p><p>  現(xiàn)在我國的中小學校中學籍的管理水平還停留在紙介質(zhì)的基礎(chǔ)上,這樣的機制已經(jīng)不能適應(yīng)時代的發(fā)展,因為它浪費了許多人力和物力,在信息時代這種傳統(tǒng)的管理方法必然被計算機為基礎(chǔ)的信息管理所取代。</p><p>  作為一個計算機應(yīng)用的本科生,希望可以在這方面有所貢獻。改革的總設(shè)計師鄧小平同志說過“科學技術(shù)是第一生產(chǎn)力”,我希望能用我四

7、年的所學編制出一個實用的程序來幫助中小學進行更有效的學籍管理。</p><p>  歸納起來,好處大約有以下幾點:</p><p>  1.可以存儲歷屆的學生學籍,安全、高效;</p><p>  2.只需一到二名學籍錄入員即可操作系統(tǒng),節(jié)省大量人力;</p><p>  3.可以迅速查到所需信息。 </p><p>

8、  1.2 學籍管理系統(tǒng)概述</p><p>  1.2.1 開展該系統(tǒng)的原因</p><p>  由于現(xiàn)今的學籍管理非常繁瑣,行政人員付出大量的工作時間,得到的效率很低。因此為提高工作效率,減輕校方人員的工作負擔,決定開發(fā)學籍管理系統(tǒng)軟件。 1.2.2 該工程的基本目標</p><p>  開發(fā)此學籍管理系統(tǒng)軟件,以供教學人員及操作者進行學籍管理,方便操作者隨時

9、添加、查詢、修改等。為了我們提高軟件開發(fā)的能力,學習漢語編程的技巧,提高工作設(shè)計思想,通過本次的工程開發(fā),開發(fā)小組成員與輔助老師,公司的技師交流,能從中學習知識吸取經(jīng)驗,再技術(shù)和軟件思想上同時得到鍛煉和提高,從而使總體水升到一個新的高度。</p><p>  1.3 開發(fā)環(huán)境以及開發(fā)工具介紹</p><p>  該軟件是在Windows 2000 Advanced Server + Vis

10、ual Basic 6.0 + SQL Server 2000的環(huán)境下完成的。下面就對這些開發(fā)工具進行介紹:</p><p>  1.3.1 Visual Basic 6.0</p><p>  微軟公司的Visual Basic 6.0是Windows應(yīng)用程序開發(fā)工具,是目前最為廣泛的、易學易用的面向?qū)ο蟮拈_發(fā)工具。Visual Basic提供了大量的控件,這些控件可用于設(shè)計界面和實現(xiàn)各

11、種功能,減少了編程人員的工作量,也簡化了界面設(shè)計過程,從而有效的提高了應(yīng)用程序的運行效率和可靠性。利用VISUAL BASIC 程序設(shè)計語言,可以很方便地設(shè)計出在WINDOWS環(huán)境下運行的應(yīng)用程序。故而,實現(xiàn)本系統(tǒng)VB是一個相對較好的選擇。</p><p>  1.3.1.1 Visual Basic的編程特點</p><p>  Visual Basic語言的出現(xiàn)為Windows下的編程

12、提出了一個新概念,利用Visual Basic的動態(tài)數(shù)據(jù)交換、對象的鏈接和嵌入、動態(tài)鏈接庫、ActiveX技術(shù)可以很方便地設(shè)計出功能強大的應(yīng)用程序。</p><p>  利用Visual Basic語言編程有以下幾個特點:</p><p><b>  可視化程序設(shè)計</b></p><p>  在Visual Basic中開發(fā)的應(yīng)用程序,不但有

13、豐富的圖形界面,同時由用戶為開發(fā)圖形界面添加的代碼真是少而又少,因為在設(shè)計圖形界面的過程中只需設(shè)置 ActiveX控件的屬性即可。</p><p>  強大的數(shù)據(jù)庫和網(wǎng)絡(luò)功能</p><p>  隨著Visual Basic 語言的向前發(fā)展,它在數(shù)據(jù)庫和網(wǎng)絡(luò)方面的功能優(yōu)勢就愈加明顯,利用Visual Basic 中的ODBC——開放式的數(shù)據(jù)庫訪問技術(shù)可以很方便地開發(fā)出自己的數(shù)據(jù)庫應(yīng)用程序;

14、利用 Visual Basic自帶的可視化數(shù)據(jù)管理器和報表生成器,完全可以在Visual Basic就完成數(shù)據(jù)庫的開發(fā)工作。</p><p><b>  3.其它特性</b></p><p>  在Visual Basic以前的版本中,由于仍然擺脫不了解釋執(zhí)行的代碼運行機制,所以在相當?shù)某潭壬现萍s了 Visual Basic 的發(fā)展。</p><p

15、>  從Visual Basic5.0版本開始,在Visual Basic 中制作的應(yīng)用程序都改變?yōu)榫幾g執(zhí)行,使得Visual Basic的代碼效率有了很大的提高,同時執(zhí)行的速度 也加快了解30%(同Visual Basic4.0相比)。</p><p>  當然在 Visual Basic中還有其它特性,例如:</p><p>  面向?qū)ο蟮木幊陶Z言;</p><

16、;p><b>  結(jié)構(gòu)化程序設(shè)計;</b></p><p>  事件驅(qū)動的程序設(shè)計:</p><p>  在傳統(tǒng)的或“過程化”的應(yīng)用程序中,應(yīng)用程序自身控制了執(zhí)行哪一部分代碼和按何種順序執(zhí)行代碼。從第一行代碼執(zhí)行程序并按應(yīng)用程序中預(yù)定的路徑執(zhí)行,必要時才會調(diào)用過程。</p><p>  在事件驅(qū)動的應(yīng)用程序中,代碼不是按預(yù)定的路徑執(zhí)行,而

17、是在響不同的事件時執(zhí)行不同的代碼片段。事件可以由用戶操作觸發(fā)、也可以由來自操作系統(tǒng)或其它應(yīng)用程序的消息觸發(fā)、甚至由應(yīng)用程序本身的消息觸發(fā)。這些事件的順序,決定了代碼執(zhí)行的順序,因此應(yīng)用程序每次運行時所經(jīng)過的路徑都是不同的。</p><p><b>  支持動態(tài)鏈接庫;</b></p><p>  應(yīng)用程序之間的資源共享。 </p><p>  

18、1.3.1.2 VB 支持的數(shù)據(jù)庫系統(tǒng)</p><p>  VB支持對多格式的數(shù)據(jù)庫的訪問和維護,無論是Access還是Foxpro中創(chuàng)建的數(shù)據(jù)庫,都可以用VB打開,對其進行查詢、修改和刪除等操作。事實上,VB幾乎支持對市面上所有數(shù)據(jù)庫的訪問。</p><p>  VB可以訪問的數(shù)據(jù)庫可以簡單的分為三類,即:Microsoft Access格式數(shù)據(jù)庫,外部數(shù)據(jù)庫和ODBC數(shù)據(jù)庫。VB對多種

19、數(shù)據(jù)庫格式的支持,大大的增強了開發(fā)數(shù)據(jù)庫應(yīng)用程序的能力。</p><p>  1.3.1.3 Jet數(shù)據(jù)庫引擎</p><p>  Microsoft引擎為Visual Basic與數(shù)據(jù)庫的接口提供了基本的方法。Jet引擎被Visual Basic,Microsoft Access和其他Microsoft產(chǎn)品共享。Jet數(shù)據(jù)庫引擎提供了多種功能,Jet的數(shù)據(jù)定義功能支持對表、索引、查詢的創(chuàng)

20、建、修改和刪除。Jet以主鍵標和表間引用完整性的形式支持數(shù)據(jù)完整性。</p><p>  對于數(shù)據(jù)操縱,Jet支持使用SQL。SQL提供用單獨語句對基于用戶定義標準的記錄組進行檢索、添加、刪除或更新的方法。</p><p>  Jet也提供對安全功能的支持。這種功能讓開發(fā)者指定用戶標識符和口令,他們必須在用戶訪問數(shù)據(jù)庫之前給出。Jet也支持使用許可,或是對單個表和查詢的訪問級別(例如,只讀

21、或讀寫可訪問性)。這是的數(shù)據(jù)庫管理員要對每一位用戶或用戶組分配對數(shù)據(jù)庫不同特定訪問。</p><p>  除了數(shù)據(jù)操作和數(shù)據(jù)定義任務(wù)外,也可用Jet引擎來執(zhí)行其他的任務(wù)。Jet還具備在數(shù)據(jù)庫開發(fā)工作中所需的其他功能,這些功能包括:數(shù)據(jù)庫修復,數(shù)據(jù)庫壓縮(以使消除不同的空間)和重新索引。</p><p>  1.3.1.4 數(shù)據(jù)庫開發(fā)中的三大工具</p><p>  

22、Visual Basic在數(shù)據(jù)庫應(yīng)用程序的開發(fā)領(lǐng)域中,提供包含數(shù)據(jù)管理(DataManager),數(shù)據(jù)控件(Data Control)以及數(shù)據(jù)編程對象(數(shù)據(jù)訪問對象(DAO)、遠程數(shù)據(jù)對象(RDO)和ActiveX數(shù)據(jù)對象(ADO))等功能強大的工具,協(xié)助設(shè)計人員輕松的連接數(shù)據(jù)庫文件,并訪問其中的數(shù)據(jù),在功能方面與其他一些專業(yè)數(shù)據(jù)庫軟件(如FoxPro,Micosoft Access等)不相上下。</p><p>

23、;  數(shù)據(jù)管理器(Data Manager)是Visual Basical已有的老成員之一,拓本盛舉有的Jet數(shù)據(jù)庫引擎(Database Engine)可以幫助VB程序元件立即維護數(shù)據(jù)庫內(nèi)容,并可通過輸入查詢或查找數(shù)據(jù)庫信息,而不必再通過其他數(shù)據(jù)庫軟件另外去設(shè)計數(shù)據(jù)庫。</p><p>  數(shù)據(jù)控件是VB所提供的基本控件成員之一。它使得設(shè)計者省下一堆程序代碼編寫的工作,能夠輕松的設(shè)計及維護數(shù)據(jù)庫內(nèi)容。數(shù)據(jù)控件可

24、以通過一些屬性的設(shè)置去鏈接某個數(shù)據(jù)庫文件,但是它本身并無法顯示數(shù)據(jù)庫各個記錄的內(nèi)容,必須在搭配其他具有數(shù)據(jù)感知(Data Aware)功能的控件對應(yīng)并顯示一個字段內(nèi)容,以方便地進行記錄的瀏覽及編輯工作。</p><p>  VB提供的數(shù)據(jù)訪問對象(Data Access Object;DAO)讓程序設(shè)計者擁有更大的發(fā)揮空間。借助程序代碼編寫,直接控制Jet數(shù)據(jù)庫引擎,配合數(shù)據(jù)庫控件,能夠開發(fā)出更具彈性且高效率的數(shù)

25、據(jù)應(yīng)用程序。</p><p>  RDO是處理遠程數(shù)據(jù)庫的一些專門需要的對象集合。使用RDO可以不用本地的查詢機就能訪問ODBC數(shù)據(jù)源,這無疑將大大提高應(yīng)用程序的性能。</p><p>  ADO是VB6。0中新增的對象,它是一個更簡單的對象模型,它更好的集成了其它數(shù)據(jù)訪問技術(shù),并且對本地和遠程數(shù)據(jù)庫均有共同的界面,可以取代DAO和RDO。ADO更易于使用。</p><

26、p>  我們在本系統(tǒng)中利用數(shù)據(jù)管理器創(chuàng)建了數(shù)據(jù)庫及數(shù)據(jù)庫表,并采用了ADO數(shù)據(jù)訪問技術(shù)。</p><p>  1.3.2 SQL Server 2000簡介</p><p>  SQL Server 2000是微軟公司最新版的大型數(shù)據(jù)庫服務(wù)器,其性能指標在各方面都有趕超Oracle數(shù)據(jù)庫的趨勢。用它可以方便地管理數(shù)據(jù)庫和開發(fā)應(yīng)用程序,它使用了最先進的數(shù)據(jù)庫構(gòu)架,與Windows N

27、T/2000平臺緊密集成,具有完全的Web功能。通過對高端硬件平臺、網(wǎng)絡(luò)和存儲技術(shù)的支持,為WEB站和企業(yè)的應(yīng)用最大限度地提供了可擴展性和高可靠性,能在Internet商業(yè)領(lǐng)域快速建立并應(yīng)用。此外,還增強了安全性,保護防火墻內(nèi)外的數(shù)據(jù)。支持基于角色的安全并擁有安全審計工具。在經(jīng)歷了SQL Server 6.5和7.0兩個版本的嘗試后,微軟公司終于開始了大規(guī)模的業(yè)務(wù)。記得在以前各種關(guān)于SQL Server的文章,都會將其定位成中小型應(yīng)用方

28、面,這種感覺被大家自然的延續(xù)到了2000版之中。其實這是一種誤解。在過去的很長一段時間中,微軟公司聘請了世界上最優(yōu)秀的數(shù)據(jù)庫專家以及專門搭建了信息量可謂空前的地理信息系統(tǒng),勵精圖治,就是為了摘掉扣在自己頭上的這頂帽子。有了強大的性能和功能支持,再配合其一向為人稱道的易用性,SQL Server可以說成為了開發(fā)者手中的一柄利器! 另外,目前國內(nèi)的</p><p>  1.3.2.1 SQL Server數(shù)

29、據(jù)庫特點</p><p>  概括起來,SQL Server 2000數(shù)據(jù)庫管理系統(tǒng)具有以下主要特點。</p><p>  1.豐富的圖形管理工具,使系統(tǒng)管理、操作更為直觀方便。SQL Server企業(yè)管理器是一個基于圖形用戶界面(GUI)的集成管理工具,利用它可以配置管理SQL Server服務(wù)器、管理數(shù)據(jù)庫和數(shù)據(jù)庫對象、備份和恢復數(shù)據(jù)、調(diào)度任務(wù)和管理警報、實現(xiàn)數(shù)據(jù)復制和轉(zhuǎn)換操作等。此外

30、,SQL Server 2000還提供了SQL事件探查器、SQL查詢分析器、SQL Server服務(wù)管理器和多種操作向?qū)У葓D形界面管理工具,大大簡化了用戶操作,從而增強了系統(tǒng)的易用性。</p><p>  2.動態(tài)自動管理和優(yōu)化功能。即使SQL Server數(shù)據(jù)庫管理員不做任何設(shè)置,SQL Server也能夠在運行過程中根據(jù)環(huán)境配置和用戶訪問情況動態(tài)自動配置,以達到最優(yōu)性能,從而減輕管理員工作。</p>

31、;<p>  3.充分的Internet技術(shù)支持。Internet網(wǎng)絡(luò)發(fā)展到今天已經(jīng)成為一條重要的信息發(fā)布渠道,SQL Server增強了對Internet技術(shù)支持,它除保留了前期版本中的數(shù)據(jù)庫Web出版工具“Web助手”外,還增強了對XML和HTTP技術(shù)的支持,這使得電子商務(wù)系統(tǒng)能夠通過XML等訪問SQL Server數(shù)據(jù)庫系統(tǒng),也擴展了SQL Server在數(shù)據(jù)挖掘和分析服務(wù)領(lǐng)域的應(yīng)用。</p><

32、p>  4.豐富的編程接口工具,使用戶開發(fā)SQL Server數(shù)據(jù)庫應(yīng)用程序更加靈活。SQL Server提供了Transact-SQL、DB-Library for C、嵌入式SQL(ESQL)等開發(fā)工具,Transact-SQL與工業(yè)標準SQL語言兼容,并在其基礎(chǔ)上加以擴充,使它更適合事務(wù)處理方面的需要。此外,SQL Server 2000還支持ODBC、OLE DB、ADO規(guī)范,可以使用ODBC、OLE DB、ADO接口訪問

33、SQL Server數(shù)據(jù)庫。</p><p>  5.具有很好的伸縮性和可靠性。SQL Server 2000既能運行在Windows桌面操作系統(tǒng)下,又可運行在服務(wù)器操作系統(tǒng)(包括Windows NT和Windows 2000)下;既能運行在單CPU計算機上,又能運行在對稱多處理系統(tǒng)下。所以,它具有很好的伸縮性,能夠滿足從桌面應(yīng)用到大型企業(yè)分布式應(yīng)用到不同層次用戶的要求。</p><p>

34、  6.簡單的管理方式。SQL Server 2000與Microsoft Windows 2000有機集成,所以可以使用Windows 2000的活動目錄(Active Directory)功能對SQL Server進行集中管理,大大簡化大型企業(yè)中的系統(tǒng)管理工作。此外,與Windows 2000的集成還使SQL Server能夠充分利用操作系統(tǒng)所提供的服務(wù)和功能(如安全管理、事件日志、性能監(jiān)視器、內(nèi)存管理和異步I/O等),從而增強了S

35、QL Server數(shù)據(jù)庫系統(tǒng)的功能,并且只需要占用很少的系統(tǒng)資源。</p><p>  1.3.3 ADO對象概述</p><p>  ADO對象是針對當前微軟的軟件所支持的數(shù)據(jù)進行操作的最為有效、簡單并且功能強大的方法。它可以把大部分數(shù)據(jù)源可編程的屬性直接擴展到Active Server上,主要含有Connection、Recordset與Command三種對象。其中:Connectio

36、n對象主要負責打開或連接數(shù)據(jù)庫文件;Recordset對象主要是存取數(shù)據(jù)庫的內(nèi)容;Command對象主要是對數(shù)據(jù)庫下達行動查詢指令以及SQL Server的Stored Proceduce。</p><p>  ADO對象能夠存取到數(shù)據(jù)庫的內(nèi)容,首先要求數(shù)據(jù)庫的驅(qū)動程序( ODBC驅(qū)動程序與OLE DB驅(qū)動程序)必須安裝上,否則,ADO對象是無法存取數(shù)據(jù)庫中內(nèi)容,其原理示意圖如圖1.1所示:</p>

37、<p>  圖1.1 ADO對象存取數(shù)據(jù)原理示意圖</p><p>  請注意:上圖中的“各種數(shù)據(jù)庫所對應(yīng)的驅(qū)動程序”即ODBC驅(qū)動程序與OLE DB驅(qū)動程序。</p><p>  1.3.3.1 利用ADO開發(fā)網(wǎng)絡(luò)數(shù)據(jù)庫應(yīng)用程序</p><p>  ADO(Active Date Objects,即ActiveX數(shù)據(jù)對象)是一個ASP內(nèi)置的Active

38、X服務(wù)器組件(ActiveX Server Component)??砂阉cASP結(jié)合起來,建立提供數(shù)據(jù)庫信息的網(wǎng)頁內(nèi)容,對數(shù)據(jù)庫進行查詢、插入、更新、刪除等操作,并可以把在用戶端實現(xiàn)“網(wǎng)上實時更新顯示”的最新Web數(shù)據(jù)庫技術(shù)。</p><p>  要執(zhí)行ADO,服務(wù)器端必須安裝Windows NT Server 和Internet Information Server(IIS),而客戶端只要有IE或NETSCAP

39、E較新版本的瀏覽器即可。</p><p>  利用ADO開發(fā)網(wǎng)絡(luò)數(shù)據(jù)庫應(yīng)用程序有以下幾個優(yōu)點:</p><p>  ⑴ 支持客戶機/服務(wù)器結(jié)構(gòu)(Client/Server)與Web系統(tǒng)開發(fā)技術(shù)。</p><p> ?、?內(nèi)部有多個互相獨立的對象模型。</p><p>  ⑶ 支持分批修改數(shù)據(jù)庫內(nèi)容。</p><p> 

40、?、?支持多種不同的數(shù)據(jù)控制指標形式。</p><p> ?、?先進的Recordset數(shù)據(jù)高速緩存管理功能。</p><p> ?、?允許在程序中使用多個Recordset對象或者多個分批修改區(qū)塊傳送。</p><p> ?、?ADO屬于Free_threaded對象,利用它可以開發(fā)出更有效的Web應(yīng)用程序。</p><p>  1.3.3

41、.2 ADO組件的主要對象及其功能</p><p>  ADO組件又稱為數(shù)據(jù)庫訪問組件,它提供了以下七種對象:</p><p>  Connection對象:提供對數(shù)據(jù)庫的連接服務(wù)。</p><p>  Command對象:定義對數(shù)據(jù)庫源操作的命令。</p><p>  Recordset對象:由數(shù)據(jù)庫服務(wù)器所返回的記錄集。</p>

42、;<p>  ●Recordset對象的LockType屬性的設(shè)置值</p><p>  Fields對象:由數(shù)據(jù)庫服務(wù)器所返回的單一數(shù)據(jù)字段</p><p>  Parametes對象:表示Command對象的參數(shù)。</p><p>  Property對象:單獨的一個Property對象,提供屬性功能。</p><p>  

43、Error對象:提供處理錯誤的功能。</p><p>  使用ADO對象可以建立和管理數(shù)據(jù)庫的連接,按數(shù)據(jù)庫服務(wù)器的要求獲得數(shù)據(jù),執(zhí)行更新、刪除、添加數(shù)據(jù)等操作,獲取ODBC的錯誤信息等。</p><p>  1.3.3.3 用來操縱數(shù)據(jù)的SQL命令</p><p>  SQL命令是發(fā)送給數(shù)據(jù)庫并要求數(shù)據(jù)庫操作的指令,它是專門為數(shù)據(jù)庫設(shè)計的語言,比一般的計算機程序語

44、言簡單的多。SQL命令主要分成兩部分:DDL(Data Definition Language)和DML(Data Manipulation Language),其中DDL是建立數(shù)據(jù)表及數(shù)據(jù)列的指令群,而DML則是操作數(shù)據(jù)庫記錄的指令群,如數(shù)據(jù)庫記錄的添加、更新、刪除、和查詢等。</p><p>  SQL命令,包括Select、Delete、Update、Insert Into、Select Into等。<

45、;/p><p> ?、?篩選及排序記錄的Select指令</p><p>  基本句型一:Select 字段串列 From 數(shù)據(jù)表</p><p>  基本句型二:Select … From … Where 篩選條件</p><p>  基本句型三:Select … From … Order By字段串列</p><p>

46、  Select Top:限定選取數(shù)據(jù)的條數(shù)</p><p> ?、?刪除數(shù)據(jù)記錄的Delete指令</p><p>  基本語法:Delete From 數(shù)據(jù)表 Where 條件式</p><p> ?、?更新數(shù)據(jù)記錄的Update指令</p><p>  基本語法:Update 數(shù)據(jù)表Set 表達式</p><p&g

47、t; ?、?增加數(shù)據(jù)記錄的Insert Into 指令</p><p>  基本句型一:Insert Into 數(shù)據(jù)表 (字段串列) Values (字段串列)</p><p>  基本句型二:Insert Into 數(shù)據(jù)表 (字段1,字段2,…,字段n) Select …</p><p>  ⑸ 建立新數(shù)據(jù)表的Select Into 指令</p>&

48、lt;p>  該指令與“Insert Into … Select …”指令的區(qū)別是,這個指令將建立另一個新的數(shù)據(jù)表,而Insert Into是增加數(shù)據(jù)記錄到“現(xiàn)存的”數(shù)據(jù)表中。</p><p>  1.2.4 Visual Basic 6.0訪問數(shù)據(jù)庫的過程</p><p><b> ?、俣x數(shù)據(jù)庫組建</b></p><p>  Dim

49、 con As New ADODB.Connection </p><p><b> ?、诖蜷_數(shù)據(jù)庫</b></p><p>  對于SQL數(shù)據(jù)庫,其連接語句為con.Open "driver={sql server};server=</p><p>  localhost;uid=sa;pwd=;database=student&q

50、uot;。而對于Access數(shù)據(jù)庫,連接語句為</p><p>  con.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=</p><p>  " & App.Path + "\student.mdb"</p><p> ?、墼O(shè)定SQL語句,使用“Execute”

51、命令,即可開始執(zhí)行訪問數(shù)據(jù)庫的動作</p><p>  Dim rs As New ADODB.Recordset 其中rs為結(jié)果集對象(RECORDSET)</p><p> ?、荜P(guān)閉結(jié)果集對象,斷開與數(shù)據(jù)庫的連接</p><p><b>  rs.Close</b></p><p><b>  Con.Cl

52、ose</b></p><p>  第二章 系統(tǒng)整體規(guī)劃</p><p><b>  2.1數(shù)據(jù)庫的設(shè)計</b></p><p>  在系統(tǒng)設(shè)計過程中,首先要建立的就是數(shù)據(jù)庫。本數(shù)據(jù)庫采用SQL Server 2000來構(gòu)造,共使用了7個表,它們分別是用戶信息表(UserInfo)、學生信息表(StuInfo)、班級信息表(Clas

53、s)、專業(yè)信息表(Major)、學院信息表(Depart)、課程信息表(Lesson)、學生成績表(Result)。</p><p>  用戶信息表(UserInfo):</p><p>  學生信息表(StuInfo):</p><p>  班級信息表(Class):</p><p>  專業(yè)信息表(Major):</p>&

54、lt;p>  學院信息表(Depart):</p><p>  6.課程信息表(Lesson):</p><p>  7.學生成績表(Result):</p><p><b>  2.2系統(tǒng)流程圖</b></p><p>  圖2.1 系統(tǒng)流程圖</p><p>  2.3 系統(tǒng)功能分析系

55、統(tǒng)開發(fā)的目標是實現(xiàn)學生學籍管理的系統(tǒng)化、規(guī)范化和自動化,這是在</p><p>  用戶要求的基礎(chǔ)上提出來的,功能要求如下: </p><p> ?。ㄒ唬W生信息管理:能對學生信息進行添加、修改、刪除。</p><p> ?。ǘ┱n程管理:對課程進行添加、修改、刪除操作。</p><p>  (三)專業(yè)/學院設(shè)置:</p>&l

56、t;p> ?。ㄈ┛荚嚦煽児芾恚?lt;/p><p> ?。ㄋ模┎樵儗W生信息:根據(jù)學號或姓名對學生信息進行精確/模糊查詢</p><p> ?。ㄎ澹┯脩艄芾恚憾x使用本系統(tǒng)的用戶名稱及密碼 </p><p>  第三章 系統(tǒng)具體實現(xiàn)</p><p>  經(jīng)過需求分析、功能模塊設(shè)計之后要進入詳細設(shè)計階段,本階段將按系統(tǒng)的主要模塊進行論述,重在

57、闡述具體的某項功能的實現(xiàn)方法或運用到的相關(guān)技術(shù)。</p><p><b>  3.1 準備工作</b></p><p>  添加引用:單擊工程菜單中的引用選項,添加Microsoft ActiveX Data Objects 2.6 Library和Microsoft Excel 9.0 Object Library兩個引用。</p><p>

58、  添加部件:單擊工程菜單中的部件選項,添加Microsoft ADO Data Control 6.0(OLEDB)、Microsoft Common Dialog Control 6.0(SP3) 、Microsoft FlexGrid Control 6.0、Microsoft Windows Common Controls 6.0(SP4)和Microsoft Windows Common Controls-2 6.0五項。&l

59、t;/p><p><b>  3.2 模塊設(shè)計</b></p><p>  添加兩個模塊module1和module2,在module1中添加如下代碼</p><p>  Option Explicit</p><p>  Global con As New ADODB.Connection</p><p

60、>  Global rs As New ADODB.Recordset</p><p>  Global classid As String, stuid As String</p><p>  Global LoginUser As String, LoginPower As String </p><p>  LoginUser記錄當前登陸用戶的用戶名,

61、LoginPower記錄當前登陸用戶的權(quán)限</p><p>  Dim Userid As String, Userpwd As String, Username As String, Userpower As String</p><p>  Dim sqlstr As String</p><p>  Sub Main()</p><p>

62、;  If App.PrevInstance = True Then</p><p>  MsgBox "注意程序已經(jīng)運行,不能再次裝載!", vbOKOnly</p><p><b>  Exit Sub</b></p><p><b>  Else</b></p><p> 

63、 Con.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&App.Path+"\student.mdb"</p><p>  Frmlogin.Show</p><p><b>  End If</b></p><p><b> 

64、 End Sub</b></p><p>  在module2中添加代碼(MD5算法)</p><p>  詳細代碼見程序中module2.bas</p><p>  3.3 用戶界面實現(xiàn)</p><p>  3.3.1 登陸界面(frmlogin)</p><p>  因為本系統(tǒng)是按學籍管理的思想設(shè)計的,

65、故而登陸部分主要完成密碼校驗、確定管理員等功能,對于密碼本系統(tǒng)采用的是MD5算法。這里附上本程序的登陸界面,見圖3.1。</p><p>  圖3.1 用戶登陸界面</p><p>  在代碼窗口的“通用”部分,定義一個模塊級的公共變量loginno用來記錄當前密碼輸入錯誤的次數(shù)</p><p>  Dim loginno As Integer</p>

66、<p>  在Form的Load事件中,將txtuser設(shè)置為焦點,初始化loginno。</p><p>  Private Sub Form_Load()</p><p>  loginno = 0</p><p><b>  Me.Show</b></p><p>  txtuser.SetFocus&

67、lt;/p><p><b>  End Sub</b></p><p>  這里將“確定”和“取消”兩個按鈕作為一個按鈕數(shù)組cmdOkCancel:確定按鈕的index屬性為0,取消按鈕的index屬性為1。</p><p>  利用SQL語句,在數(shù)據(jù)庫中查詢,如果查到相應(yīng)的記錄,則調(diào)用Case 0事件,用戶的登陸獲得通過,此時可以退出登陸窗口,并

68、進入MDI主窗口,同時將用戶類型和用戶名分別傳遞到MDI主窗口和frmmanage中;如果沒有相應(yīng)的記錄,則給出提示錯誤信息,同時將用戶輸入錯誤密碼次數(shù)增加1,如果錯誤超過3次,則退出整個系統(tǒng);若次數(shù)還沒有超過3次,則提示用戶重新輸入。</p><p>  根據(jù)以上的設(shè)計,cmdOkCancel的Click事件的代碼如下:</p><p>  Private Sub cmdOkCancel

69、_Click(Index As Integer)</p><p>  Select Case Index</p><p><b>  Case 0</b></p><p><b>  ……</b></p><p>  Userid = Trim(txtuser.Text)</p>&l

70、t;p>  Userpwd = MD5(Trim(txtPassword.Text))</p><p>  sqlstr = "select * from UserInfo where UserID='" & Userid & "'"</p><p>  rs.Open sqlstr, con, 1, 1<

71、/p><p>  If Not rs.EOF Then</p><p>  If rs("UserPWD") <> Userpwd Then</p><p><b>  '密碼錯誤時</b></p><p>  MsgBox "您輸入的密碼不正確!", vbQues

72、tion</p><p>  Me.Caption = "請輸入用戶名和密碼:"</p><p>  loginno = loginno + 1</p><p>  '當錯誤的密碼次數(shù)達到3次時,不能登陸,退出!</p><p>  If loginno = 3 Then</p><p> 

73、 MsgBox "對不起,您不能使用該系統(tǒng)!請與管理員聯(lián)系。", vbInformation</p><p><b>  Unload Me</b></p><p><b>  Exit Sub</b></p><p><b>  End If</b></p><

74、;p><b>  ……</b></p><p><b>  Else</b></p><p>  LoginUser = Userid '保存當前登陸用戶名</p><p>  LoginPower = rs.Fields(3) </p><p>  '將當前登陸用

75、戶的權(quán)限保存到LoginPower中</p><p><b>  Unload Me</b></p><p>  frmflash.Show</p><p><b>  End If</b></p><p><b>  Else</b></p><p>

76、  MsgBox "沒有您輸入的用戶名!", 32</p><p><b>  ……</b></p><p><b>  End If</b></p><p>  rs.Close: Set rs = Nothing</p><p><b>  Case 1</b

77、></p><p><b>  ‘退出整個程序</b></p><p><b>  Unload Me</b></p><p>  End Select</p><p><b>  End Sub</b></p><p>  3.3.2 MDI主窗

78、口(frmmain)</p><p>  本系統(tǒng)采取多文檔界面(MultiDocument Interface)。多文檔界面是一種Windows用戶界面標準。它有一個父窗口,在典型情況下,父窗口用來顯示程序菜單以及包含子窗口。</p><p>  在工程中添加一個MDI窗口,取名為“frmmain.frm”,并為MDI窗體進行菜單和代碼的設(shè)計,其運行界面如圖3.2:</p>

79、<p><b>  圖3.2 主界面</b></p><p>  3.3.2.1 菜單設(shè)計</p><p>  MDI主窗體是整個系統(tǒng)的容器,為了方便用戶的使用,應(yīng)設(shè)計相應(yīng)的菜單和代碼。</p><p>  3.3.2.2 窗體代碼設(shè)計</p><p>  1.在代碼窗口的通用部分,聲明一個API函數(shù)用于打開幫

80、助文件和調(diào)用Outlook發(fā)送郵件。</p><p>  Private Declare Function ShellExecute& Lib "shell32.dll" Alias "ShellExecuteA" (ByVal hwnd As Long, ByVal lpOperation As String, ByVal lpFile As String, By

81、Val lpParameters As String, ByVal lpDirectory As String, ByVal nShowCmd As Long)</p><p><b>  2.判斷用戶權(quán)限</b></p><p>  如果登陸的為普通用戶類型的用戶,則用戶不能使用“用戶管理”這一功能,而對于管理員類型的用戶,則沒有此限制。所以在MDIForm的Loa

82、d事件中需要判斷用戶類型。</p><p>  Private Sub MDIForm_Load()</p><p>  StatusBar.Panels(2).Text = "當前操作員:" & LoginUser & " " & LoginPower & ""</p><

83、;p>  If LoginPower = "普通用戶" Then</p><p>  filemenu11.Enabled = False</p><p>  Toolbar1.Buttons.Item(5).Enabled = False</p><p><b>  End If</b></p><

84、;p><b>  End Sub</b></p><p>  3.Form的QueryUnload事件</p><p>  當用戶要退出MDI窗體時,需要在 QueryUnload事件中詢問用戶是否真的要退出本系統(tǒng);如果用戶不要退出,則將Cancel置為1,取消整個退出過程。</p><p>  Private Sub MDIF

85、orm_QueryUnload(Cancel As Integer, UnloadMode As Integer)</p><p>  If MsgBox("確定要退出學生檔案管理系統(tǒng)嗎?是/否",</p><p>  vbYesNo+vbQuestion+ vbDefaultButton1) = vbNo Then</p><p>  Canc

86、el = 1</p><p><b>  End If</b></p><p><b>  End Sub</b></p><p>  QueryUnload和Unload事件</p><p>  當一個子窗體或一個Form對象關(guān)閉時,在那個窗體中的QueryUnload事件先于該窗體的Unload

87、事件發(fā)生,Unload事件在Terminate事件之前發(fā)生。</p><p>  當一個應(yīng)用程序關(guān)閉時,可使用QueryUnload或Unload事件過程將Cancel屬性設(shè)置為True來阻止關(guān)閉過程。但是,QueryUnload事件是在任一個卸載之前在所有窗體中發(fā)生,而Unload是在每個窗體卸載時發(fā)生。</p><p>  在這兩個事件中,均可將Cancel設(shè)置為任何非零的值來防止窗體

88、被刪除。但Unload不能阻止其他事件,諸如從Microsoft Windows操作環(huán)境中退出等;而QueryUnload事件則可以阻止從Windows中的退出。有介于此,通常來說都是在QueryUnload中詢問用戶是否要退出當前窗體。</p><p>  4.“重新登陸”子菜單的代碼</p><p>  當單擊了“重新登陸”或者按下了“F2”鍵時,將會給出提示,如果用戶在提示框中按下了

89、“確定”按鈕,則退出整個MDI主窗體,并顯示登陸窗體。</p><p>  Private Sub filemenu15_Click()</p><p>  If MsgBox("若重新登陸,所有窗體都將關(guān)閉!是否重新登陸?", vbYesNo + vbQuestion, "重新登陸") = vbYes Then</p><p

90、>  Unload Me Frmlogin.Show</p><p><b>  End If</b></p><p><b>  End Sub</b></p><p>  5.“幫助主題”子菜單的代碼</p><p>  調(diào)用Windows API函數(shù),打開help.chm幫助

91、文件。</p><p>  Private Sub filemenu21_Click()</p><p>  ShellExecute 0, "open", App.Path & "\help.chm", "", "", 1</p><p><b>  End Sub&

92、lt;/b></p><p>  6.“給我發(fā)郵件”子菜單的代碼</p><p>  如果用戶單擊了“給我發(fā)郵件”子菜單,則會調(diào)用API函數(shù),調(diào)用Outlook。</p><p>  Private Sub filemenu22_Click()</p><p>  ShellExecute Me.hwnd, "open&quo

93、t;, "mailto:datou158@etang.com", "", App.Path, 1</p><p><b>  End Sub</b></p><p>  7.當用戶單擊查詢學生資料菜單項或者按下F3鍵時,將會出現(xiàn)“查找學生”窗體,供用戶查找滿足特定要求的學生信息。</p><p>  Pr

94、ivate Sub filemenu45_Click()</p><p><b>  '查找學生</b></p><p>  frmstusearch.Show 1</p><p><b>  End Sub</b></p><p>  3.3.3 用戶管理窗體(frmmanage)<

95、/p><p>  向項目中添加窗體,并命名為frmmanage.frm。窗體的控件設(shè)計如圖3.3所示</p><p>  圖3.3 用戶管理界面</p><p>  如果登陸的用戶類型是管理員,用戶管理一項是可用的,當單擊該子菜單時,將會出現(xiàn)用戶管理窗口,管理員可以對系統(tǒng)用戶進行添加和刪除操作。</p><p>  3.3.3.1 窗體代碼設(shè)計&

96、lt;/p><p>  1.定義一個整型變量DelNO用來存儲當前系統(tǒng)用戶的數(shù)目,當DelNO<=1時提示用戶不能再刪除用戶。在該窗體的通用部分寫如下代碼:</p><p>  Dim DelNO As Integer</p><p>  2.窗體加載時,初始化Listview用以顯示系統(tǒng)用戶列表,代碼如下</p><p>  Privat

97、e Sub Form_Load()</p><p>  '初始化ListView</p><p>  Dim clmX As ColumnHeader</p><p>  Set clmX = ListView.ColumnHeaders.Add(, , "用戶名", ListView.Width / 3)</p><

98、p>  Set clmX = ListView.ColumnHeaders.Add(, , "密碼", ListView.Width / 6, 2)</p><p>  Set clmX = ListView.ColumnHeaders.Add(, , "姓名", ListView.Width / 4, 2)</p><p>  Set clm

99、X = ListView.ColumnHeaders.Add(, , "用戶權(quán)限", ListView.Width / 4, 2)</p><p>  Combo1.Clear</p><p>  Combo1.AddItem "普通用戶"</p><p>  Combo1.AddItem "超級用戶"&l

100、t;/p><p>  Combo1.ListIndex = 0</p><p>  LoadOperator</p><p><b>  End Sub</b></p><p>  其中調(diào)用了LoadOperator函數(shù),該函數(shù)用來顯示和刷新Listview中的數(shù)據(jù)</p><p>  Private

101、 Sub LoadOperator()</p><p>  On Error Resume Next</p><p>  Dim Listit As ListItem</p><p>  ListView.ListItems.Clear</p><p>  ListView.LabelEdit = lvwAuto</p><

102、;p>  ListView.View = 3</p><p>  Dim ef As New ADODB.Recordset</p><p>  sqlstr = "select * from UserInfo"</p><p>  ef.Open sqlstr, con, 1, 1</p><p>  DelNO

103、= ef.RecordCount</p><p>  Do While Not ef.EOF</p><p>  Set Listit = ListView.ListItems.Add(, , ef.Fields("UserID"))</p><p>  Listit.SubItems(1) = "***" </p&g

104、t;<p>  隱藏用戶的密碼,用***來替代。</p><p>  Listit.SubItems(2) = ef("UserName")</p><p>  Listit.SubItems(3) = ef("UserPower")</p><p>  ef.MoveNext</p><p&

105、gt;<b>  Loop</b></p><p>  Set ef = Nothing</p><p><b>  End Sub</b></p><p><b>  3.添加用戶</b></p><p>  在Textbox中輸入了相應(yīng)的數(shù)據(jù)以后,按添加按鈕則調(diào)用該按鈕的C

106、lick事件,代碼如下</p><p>  當單擊“添加”按鈕時,首先檢查輸入的用戶名和密碼是否為空,代碼如下:</p><p>  Private Sub Command4_Click()</p><p>  If Trim(Text1.Text) = "" Then</p><p>  MsgBox "登陸用

107、戶名不允許為空!", vbOKOnly + 48, "提示:"</p><p>  Text1.SetFocus</p><p><b>  Exit Sub</b></p><p><b>  End If</b></p><p>  If InStr(1, Trim

108、(Text1.Text), "'", vbTextCompare) Then</p><p>  MsgBox "用戶姓名中有特殊字符" + "<'>,請刪除。", vbOKOnly + 48, "提示:"</p><p>  Text1.SetFocus</p>&l

109、t;p><b>  Exit Sub</b></p><p><b>  End If</b></p><p>  If Trim(Text2.Text) = "" Then</p><p>  MsgBox "密碼不能為空,請輸入密碼!", vbOKOnly + 48, &q

110、uot;提示:"</p><p>  Text2.Text = ""</p><p>  Text3.Text = ""</p><p>  Text2.SetFocus</p><p><b>  Exit Sub</b></p><p><

111、;b>  End If</b></p><p><b>  End Sub</b></p><p>  如果不為空,則檢查用戶名是否有重復,需要打開系統(tǒng)信息表,</p><p>  Private Sub Command4_Click()</p><p><b>  ……</b>&

112、lt;/p><p>  sqlstr = "select * from UserInfo where UserID='" & Text1.Text & "'"</p><p>  rs.Open sqlstr, con, 1, 1</p><p><b>  End Sub</b&g

113、t;</p><p>  如果當前記錄不為空,則逐條記錄檢查是否有重復</p><p>  Private Sub Command4_Click()</p><p><b>  ……</b></p><p>  Userid = Trim(Text1.Text)</p><p>  Userpwd

114、 = MD5(Trim(Text2.Text))</p><p>  Username = Trim(Text4.Text)</p><p>  Userpower = Trim(Combo1.Text)</p><p>  DelNO = rs.RecordCount</p><p>  Do While Not rs.EOF</p&

115、gt;<p><b>  ……</b></p><p>  rs.MoveNext</p><p><b>  Loop</b></p><p><b>  ……</b></p><p><b>  End Sub</b></p>

116、<p>  如果有重復,則提示已存在這個用戶,然后將焦點設(shè)置給Text1,并將所有的文本框清空。</p><p>  Private Sub Command4_Click()</p><p><b>  …… </b></p><p>  Do While Not rs.EOF</p><p>  If T

117、ext1.Text = rs.Fields("UserID") Then</p><p>  MsgBox "已經(jīng)存在用戶名為 " & Userid & " 的用戶帳號", vbInformation</p><p>  Text1.SetFocus</p><p><b>  E

118、xit Sub</b></p><p><b>  End If</b></p><p>  rs.MoveNext</p><p><b>  Loop</b></p><p>  rs.Close: Set rs = Nothing</p><p><b

119、>  End Sub</b></p><p>  如果沒有重復,再檢查兩次輸入的密碼是否一致,如果不一致,則提示“兩次密碼不一致”。</p><p>  Private Sub Command4_Click()</p><p><b>  ……</b></p><p>  If Trim(Text3.T

120、ext) <> Trim(Text2.Text) Then</p><p>  MsgBox "兩次密碼不相同,請重輸入!", vbOKOnly + 48, "提示:"</p><p>  Text2.Text = ""</p><p>  Text3.Text = ""&l

121、t;/p><p>  Text2.SetFocus</p><p><b>  Exit Sub</b></p><p><b>  End If</b></p><p><b>  End Sub</b></p><p>  如果以上全部正確無誤的設(shè)置好了

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論