




已閱讀5頁,還剩58頁未讀, 繼續(xù)免費閱讀
版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 本文配套程序下載地址 : 無憂無慮畢設網(wǎng) ()-大學生畢業(yè)設計站 ,免費畢業(yè)設計論文 ,無憂無慮畢設網(wǎng) 大學生畢業(yè)設計 ,出售各類畢業(yè)設計源碼 ,論文 ,程序源碼 ,網(wǎng)站源碼 ,免費視頻教程 ,我們將竭誠為您服務! 畢業(yè)設計 院系 _ 專業(yè) _ 班級 _ 姓名 _ 日期 年 月 日 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 中文摘要 水電管理系統(tǒng) 為水電收費管理人員日常工作的抄表 ,報表生成 ,費用計算等提供充足的信 息和快捷的查詢手段 .其開發(fā)內(nèi)容主要包括后臺數(shù)據(jù)庫的建立和維護以及前端應用程序的開發(fā)兩個方面。利用 DELPHI 6.0 軟件及其提供的各種面向?qū)ο蟮拈_發(fā)工具,建立完整性強、安全性好的數(shù)據(jù)庫,開發(fā)出功能完備,易使用的應用程序。經(jīng)過調(diào)試、編譯與實現(xiàn),該程序 界面友好、程序設計風格樸素,使用起來美觀大方、方便易用。尤其是系統(tǒng)的“報表生成模塊”的功能極大的減輕工作人員的工作量,并以快速、準確等優(yōu)點取代人工操作, 提高了水電管理工作效率。 關鍵詞 : DELPHI 6.0 信息管理系統(tǒng) 數(shù)據(jù)庫 模塊 水電管理 系統(tǒng) 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: Utilities Management System for management of day-to-day work of the utility meter-reading fee, statements generated, the cost of the provision of adequate means of information and quick enquiries. Its development mainly to the establishment and maintenance of databases including background and the development of two front-end applications. Delphi 6.0 and the use of object-oriented software development tools, the establishment of strong integrity, good safety database developed functions, easy to use applications. After debugging, Translation and the realization that the process friendly interface, simple programming style, using up aesthetic generous, convenient user-friendly. In particular system statements generated module function greatly reduce the workload of staff, and to the rapid, accurate, and other advantages replace manually operated, and enhanced power management efficiency. Keyword : Delphi 6.0 Information Management System database module utilities management system 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 引 言 1 1 Delphi 語言概述 2 1.1 Delphi 簡介 2 1.2 數(shù)據(jù)庫系統(tǒng)簡介 5 1.3 本應用軟件的基本介紹 7 2 本應用程序的構(gòu)成和開發(fā)步驟 9 2.1 可行性研究 10 2.1.1 經(jīng)濟可行性 11 2.1.2 時間可行性 12 2.1.3 技術可行性 13 2.1.4 社會可行性 14 2.2 數(shù)據(jù)庫的建立和連接 15 2.3 系統(tǒng)的總體設計 17 2.4 系統(tǒng)的詳細設計 19 3 本程序的技術實現(xiàn)及具體功能 21 3.1 登錄的界面與程序設計實現(xiàn) 24 3.2 系統(tǒng)參數(shù)配置界面與代碼設計實現(xiàn) 34 3.3 類型維護界面與代碼設計實現(xiàn) 45 3.4 抄表界面與代碼設計 52 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 3.5 報表管理界面設計與代碼設計 55 結(jié) 論 60 致 謝 61 參 考 文 獻 62 引 言 隨著經(jīng)濟的發(fā)展,社會的進步,計算機越來越深入到我們?nèi)粘5墓ぷ鲗W習及生活中,成為我們?nèi)粘I钪胁豢扇鄙俚妮o助工具。 隨著科學技術的不斷提高 ,計算機科學日漸成熟 ,其強大的功能已為人們深刻認識 ,它已進入人類社會的各個領域并發(fā)揮著越來越重要的作用。 它已經(jīng)深入到日常工作和生活的方 方面面,比如文字處理、信息管理、輔助設計、圖形圖像處理、教育培訓以及游戲娛樂等。各行各業(yè)的人們無須經(jīng)過特別的訓練就能夠使用電腦完成許許多多復雜的工作。然而,雖然現(xiàn)在世界上已經(jīng)充滿了多如牛毛的各種軟件,但它無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 們依然不能滿足用戶的各種特殊需要,人們還不得不開發(fā)適合自己特殊需求的軟件。以前開發(fā) Windows 應用軟件是專業(yè)人員的工作,需要掌握許多專業(yè)知識和經(jīng)過特殊的培訓才能勝任?,F(xiàn)在不同了,即使你沒有接受過嚴格的程序設計訓練,使用 Delphi 編程語言 也一樣能夠開發(fā)出功能強大、適合自己特殊需求的應用程序了。 Delphi 編程語言 繼承了其他語言易學易用的特點,特別適合于初學者學習Windows 系統(tǒng)編程。 水電管理系統(tǒng)用計算機管理水電收費管理人員收取轄區(qū)內(nèi)用戶費用的一種計算機應用技術的創(chuàng)新 ,在計算機還未普及之前水電收費管理都是由工作人員人工書寫 ,調(diào)閱的方式來操作的 .現(xiàn)在一般的水電管理都采用計算機智能化管理 ,采用計算機作為工具的實用的計算機網(wǎng)絡化管理程序來幫助前臺管理員進行更有效的水電管理工作。水電管理系統(tǒng) 是典型的信息管理系統(tǒng) (MIS),其開發(fā)主要包括后臺數(shù)據(jù)庫的建立和維護以及前端應用程序的開發(fā)兩個方面。對于前者要求建立 起數(shù)據(jù)一致性和完整性強、數(shù)據(jù)安全性好的庫。而對于后者則要求應用程序功能完備 ,易使用等特點。 經(jīng)過分析 ,我們使用 Delphi編程語言 開發(fā)工具 ,利用其提供的各種面向?qū)ο蟮拈_發(fā)工具 ,尤其是數(shù)據(jù)窗口這一能方便而簡潔操縱數(shù)據(jù)庫的智能化對象 ,首先在短時間內(nèi)建立系統(tǒng)應用原型 ,然后 ,對初始原型系統(tǒng)進行需求迭代 ,不斷修正和改進 ,直到形成用戶滿意的可行系統(tǒng)。 因為本人能力有限,加上時間緊迫,所以設計出來的本系統(tǒng)可能無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 功能比較簡單,另外本系統(tǒng)是單機版,不能實現(xiàn)網(wǎng)絡互聯(lián)操作 ,這些都有待于我在以后的工作學習中進一步改進。 1.1 Delphi 簡介 1.1 Delphi 簡介 Delphi是 Inprise公司出品的一個優(yōu) 秀 的可視化程序開發(fā)工具軟件,它短小精悍,但功能卻可以與龐大的 visual c+媲美。它易學易用,如同 VB,因而被稱為“第四代編程語言”。 從 1995 年推出 Delphi1.0 至今已經(jīng)經(jīng)歷了 7 個版本,Delphi7.0 運行在 win9x 或 winme , win2000, winxp,windowsNT 等操作系統(tǒng)下,是一個 32 位的應用程序開發(fā)工具。這里把“ VB”比作是傻瓜相機, Delphi 是帶有自動功能的專業(yè)相機。前些年, 軟件界流行一句話叫“真正的程序員用 VC,聰明的程序員用 Delphi”。也有的把 Delphi 稱作 VB殺手。 1.2 數(shù)據(jù)庫系統(tǒng)簡介 數(shù)據(jù)庫系統(tǒng)是一個實際可運行的存儲、維護和應用系統(tǒng)提供數(shù)據(jù)的軟件系統(tǒng),是存儲介質(zhì)、處理對象和管理系統(tǒng)的集合體。它通常由軟件、數(shù)據(jù)庫和數(shù)據(jù)管理員組成。其軟件無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 主要包括操作系統(tǒng)、各種宿主語言,實用程序以及數(shù)據(jù)庫管理系統(tǒng)。數(shù)據(jù)庫是依照某種數(shù)據(jù)模型組織起來并存放二級存儲器中的數(shù)據(jù)集合。這些數(shù)據(jù)為多個應用服務,獨立于具體的應用程序。數(shù)據(jù)庫由數(shù)據(jù)庫管理系統(tǒng)統(tǒng)一管理,數(shù)據(jù)的插入、修改和檢索均要 通過數(shù)據(jù)庫管理系統(tǒng)進行。數(shù)據(jù)庫管理系統(tǒng)是一種系統(tǒng)軟件,它的主要功能是維護數(shù)據(jù)庫并有效地訪問數(shù)據(jù)庫中任意部分數(shù)據(jù)。對數(shù)據(jù)庫的維護包括保持數(shù)據(jù)的完整性、一致性和安全性。數(shù)據(jù)管理員負責創(chuàng)建、監(jiān)控和維護整個數(shù)據(jù)庫,使數(shù)據(jù)能被任何有權使用的人有效使用。數(shù)據(jù)庫管理員一般是由業(yè)務水平較高、資歷較深的人員擔任。 數(shù)據(jù)庫系統(tǒng)的個體含義是指一個具體的數(shù)據(jù)庫管理系統(tǒng)軟件和用它建立起來的數(shù)據(jù)庫;它的學科含義是指研究、開發(fā)、建立、維護和應用數(shù)據(jù)庫系統(tǒng)所涉及的理論、方法、技術所構(gòu)成的學科。在這一含義下,數(shù)據(jù)庫系統(tǒng)是軟件研究領域的一個重 要分支,常稱為數(shù)據(jù)庫領域。 數(shù)據(jù)庫研究跨越于計算機應用、系統(tǒng)軟件和理論三個領域,其中應用促進新系統(tǒng)的研制開發(fā),新系統(tǒng)帶來新的理論研究,而理論研究又對前兩個領域起著指導作用。數(shù)據(jù)庫系統(tǒng)的出現(xiàn)是計算機應用的一個里程碑,它使得計算機應用從以科學計算為主轉(zhuǎn)向以數(shù)據(jù)處理為主,并從而使計算機得以在各行各業(yè)乃至家庭普遍使用。在它之前的文件系統(tǒng)雖然也無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 能處理持久數(shù)據(jù),但是文件系統(tǒng)不提供對任意部分數(shù)據(jù)的快速訪問,而這對數(shù)據(jù)量不斷增大的應用來說是至關重要的。為了實現(xiàn)對任意部分數(shù)據(jù)的快速訪問,就要研究許多優(yōu)化技術。這些優(yōu)化 技術往往很復雜,是普通用戶難以實現(xiàn)的,所以就由系統(tǒng)軟件(數(shù)據(jù)庫管理系統(tǒng))來完成,而提供給用戶的是簡單易用的數(shù)據(jù)庫語言。由于對數(shù)據(jù)庫的操作都由數(shù)據(jù)庫管理系統(tǒng)完成,所以數(shù)據(jù)庫就可以獨立于具體的應用程序而存在,從而數(shù)據(jù)庫又可以為多個用戶所共享。因此,數(shù)據(jù)的獨立性和共享性是數(shù)據(jù)庫系統(tǒng)的重要特征。數(shù)據(jù)共享節(jié)省了大量人力物力,為數(shù)據(jù)庫系統(tǒng)的廣泛應用奠定了基礎。數(shù)據(jù)庫系統(tǒng)的出現(xiàn)使得普通用戶能夠方便地將日常數(shù)據(jù)存入計算機并在需要的時候快速訪問它們,從而使的計算機走出科研機構(gòu)進入各行各業(yè)、進入家庭。 1.3 本應用軟件的 基本介紹 本應用軟件先是打開一個啟動窗口,就可以進入應用程序的主窗口了。主界面是一個圖型界面窗口,整個平臺顯示采用人性化方式,可以非常方便的系統(tǒng)管理、字典維護、抄表 ,報表管理等基本信息,管理日常經(jīng)營的基本情況,通過各種條件查詢出水電管理的基本信息,以及打印出查詢出的基本信息,總之一切水電管理基本信息都會顯示在系統(tǒng)平臺上,大大提高了管理人員的工作效率。 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 2 本應用程序的構(gòu)成和開發(fā)步驟 下面從軟件工程的角度介紹本程序的基本開發(fā)步驟。Delphi 應用程序一般包含以下三個基本部分: 應用程序運行的接口: 負責系統(tǒng)整體環(huán)境的設置,運行狀態(tài)的監(jiān)視,應用程序的啟動等。 應用程序的主體:主要完成用戶的業(yè)務邏輯功能,如系統(tǒng)參數(shù)配置 ,字典維護 ,抄表 ,報表生成 .等信息 . 應用程序的輔助部分:協(xié)助程序主體完成的一些工作。 下面從軟件工程的角度描述本程序的開發(fā)生命周期,開發(fā)過程和組織過程。 2.1 可行性研究 任何一個系統(tǒng)或一項工程,在建立之前,必須首選進行可行性分析,可行性分析包括兩層含義,一是可能性,二是必要性??赡苄灾搁_發(fā)信息系統(tǒng)的條件是否具備,必要性是指客觀上是否真正需要,通過可行性研究,可避免盲目投資,減 少政治性要的損失。下面從四方面來討論: 2.1.1 經(jīng)濟可行性 主要是只指算一個新的系統(tǒng)開發(fā)所需要的投資費用和運算費用,并與估計的新系統(tǒng)收益進行比較,看是否有利。本系統(tǒng)所需的軟硬件成本比較低,投資小,具有一定的通過性,因此 ,在經(jīng)濟上是可行的。 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 2.1.2 時間可行性 主要包括系統(tǒng)在目前環(huán)境下能否正常運行,運行后所引起的各方面,以及這些變化對社會或人的因素所產(chǎn)生的影響。本系統(tǒng)對人事的管理比較全面,可長期使用。 2.1.3 技術可行性 利用現(xiàn)有的設備,軟件及技術人員,新系統(tǒng)的目標能否達到,這也是可行性研 究中需要考慮的一個問題。關系型數(shù)據(jù) 庫的高速發(fā)展使管理信息系統(tǒng)具備了良好的開發(fā)環(huán)境。本系統(tǒng)使用的 Delphi 普及性好,操作簡單,用戶可以很快掌握使用方法,因此,在技術上是完全可行的。 2.1.4 社會可行性 人類社會文明的發(fā)展已進入信息化的高速發(fā)展時期,傳統(tǒng)的手工方式支持下的管理模式,已經(jīng)不能滿足各方面的需要。開發(fā)本系統(tǒng)的目標不僅是提高工作效率,減輕勞動強度,而且減少出錯率,具有很好的社會意義。 2.2 數(shù)據(jù)庫的建立和連接 這個程序采用的數(shù)據(jù)庫是 Microsoft Access2000, Delphi作為 數(shù)據(jù)庫的前臺開發(fā)工具,必須與后臺數(shù)據(jù)庫進行連接,這樣才能控制和進行操作數(shù)據(jù)庫,數(shù)據(jù)庫的連接方式有兩種, ODBC 和 ADO。 ODBC 是數(shù)據(jù)庫的通用接口,其缺點是效率低;專用接口調(diào)用直接速度快,但是通用性差,如果用 ODBC 連接數(shù)據(jù)庫一般要兩個步驟: 1.要創(chuàng)建數(shù)據(jù)源; 2.創(chuàng)建描述文件。數(shù)無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 據(jù)庫的建立則時在 access2000 中建立的,在這里你可以設置數(shù)據(jù)庫的密碼,對數(shù)據(jù)庫進行保護。在創(chuàng)建數(shù)據(jù)源時可以通過 BDE administrator 進行創(chuàng)建,也可以通過系統(tǒng)控制面板中的 ODBC 數(shù)據(jù)源進行建立。而描述文件則可以在 Delphi 的主程序中用 Database Profile 中進行建立,之后進行數(shù)據(jù)庫的連接。接下來的工作是建表。同樣建表的過程也不是唯一的,但是最終實現(xiàn)的結(jié)果是唯一的。你可以通過 Access 進行建表,也可以通過在 Visual Basic 主程序中建表,也可以通過powerdesigner 進行可視化的建立,不過用這種方法,在導入的時候要把數(shù)據(jù)庫要先斷開,否則數(shù)據(jù)庫的數(shù)據(jù)容易丟失。建表的過程注意規(guī)范化命名規(guī)則,如表的字段名等等。同時也要注意表的字段長度和可否為空。因為以后要設計到主鍵,外鍵的問題。如果字段名不同, 同一字段長度不同則主鍵和外鍵將會連接不上。可見建表時應做好全局的打算。我在程序開發(fā)的初期,同樣犯了這個錯誤,導致數(shù)據(jù)庫出錯,有時還要向表中新加入字段。導致數(shù)據(jù)窗口不好用的連鎖反映。 2.3 系統(tǒng)的總體設計 這個管理系統(tǒng)從 4 月 1 日開始著手設計開發(fā) ,經(jīng)過一段時無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 間的分析,并根據(jù)對水電管理的具體要求及需要本軟件實現(xiàn)的功能,將本軟件分為 5 個大的模塊,分別是:第一部分:系統(tǒng)管理 ; 第二部分:字典維護 ; 第三部分:抄表; 第四部分:報表管理。 程序流程圖如下: 2.4 系統(tǒng)的詳細設計 程序登陸 主界面 系 統(tǒng) 管 理 字典維護 抄表 報表管理 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 進入 Access 后要做的第一件事就是建立一個數(shù)據(jù)庫。Access 提供了 6 種用構(gòu)造數(shù)據(jù)庫系統(tǒng)的對象,根據(jù)本課題的需要,在這里選擇一個空的數(shù)據(jù)庫,命名 建立了一個數(shù)據(jù)庫名稱為 “ SDManager” , 水電管理系統(tǒng)。 并在此數(shù)據(jù)庫下創(chuàng)建了 六個表,用于存放原始數(shù)據(jù)。它只是存放數(shù)據(jù),對其中數(shù)據(jù)的修改要通過對應的窗體來完成。 創(chuàng)建各表的具體結(jié)構(gòu)如下 : 1.cnfgpara 信息表 2.meter 信息表 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 3.metersort 信息表 4.price 信息表 5.takemeter 信息表 6.車間信息表 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 3 本程序的技術實現(xiàn)及具體功能 3.1 登錄的界面與程序設計實現(xiàn) 代碼設計 : unit uLogin; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, Buttons, Db, ADODB; type TfrmLogin = class(TForm) Label1: TLabel; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: Edit1: TEdit; BitBtn1: TBitBtn; BitBtn2: TBitBtn; ADOQuery1: TADOQuery; DataSource1: TDataSource; procedure FormCreate(Sender: TObject); procedure BitBtn2Click(Sender: TObject); procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure FormDestroy(Sender: TObject); procedure BitBtn1Click(Sender: TObject); private Private declarations Function GetPassWd: String; public Public declarations IsOk: Boolean; iTime: Integer; /計算登錄次數(shù) end; var frmLogin: TfrmLogin; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: implementation uses UCommon, uConst; $R *.DFM procedure TfrmLogin.FormCreate(Sender: TObject); begin ADOQuery1.ConnectionString := Format(strConnectString, ExtractFilePath(Application.ExeName); if not FileExists(ExtractFilePath(Application.ExeName) + MDBSDManager.mdb) then Begin MessageBox(Handle, 數(shù)據(jù)庫文件不存在! , 錯誤 , MB_OK or MB_ICONERROR); Application.Terminate; end else begin Try ADOQuery1.Connection; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: except MessageBox(Handle, ErrorConnectDataBase, 錯誤 , MB_OK or MB_ICONERROR); Application.Terminate; end; end; end; procedure TfrmLogin.BitBtn2Click(Sender: TObject); begin Application.Terminate; end; procedure TfrmLogin.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmLogin.FormDestroy(Sender: TObject); begin frmLogin := nil; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: end; procedure TfrmLogin.BitBtn1Click(Sender: TObject); var PS: String; begin IsOk := False; PS := Trim(Edit1.Text); if PS GetPassWd then begin if iTime = 2 then begin MessageBox(Handle, 你無權使用本系統(tǒng)! , 提示 , MB_OK or MB_ICONINFORMATION); Application.Terminate; end; MessageBox(Handle, 輸入的密碼不正確,請確認! , 登錄提示 , MB_OK or MB_ICONINFORMATION); Edit1.SetFocus; IsOk := False; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: Inc(iTime); end else begin IsOk := True; frmLogin.Close; end; end; function TfrmLogin.GetPassWd: String; begin /todo if not ADOQuery1.Active then ADOQuery1.Open; Result := ADOQuery1.Fields0.AsString; end; end. 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 3.2 系統(tǒng)參數(shù)配置界面與代碼設計實現(xiàn) 代碼設計 : unit ufrmCnfgPara; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, Mask, Buttons, Db, ADODB, ExtCtrls; type TfrmCnfgPara = class(TForm) Label1: TLabel; edtUnitName: TEdit; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: Label2: TLabel; maskPw: TMaskEdit; BitBtn1: TBitBtn; BitBtn2: TBitBtn; dsCfngPara: TDataSource; adoCfngPara: TADOQuery; Image1: TImage; procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure FormDestroy(Sender: TObject); procedure BitBtn2Click(Sender: TObject); procedure FormShow(Sender: TObject); procedure BitBtn1Click(Sender: TObject); procedure edtUnitNameKeyPress(Sender: TObject; var Key: Char); procedure maskPwKeyPress(Sender: TObject; var Key: Char); private Private declarations FQuery: TADOQuery; Procedure DeleteAllHistroyData; /刪除所有的歷史數(shù)據(jù) Procedure ModifyUnitName(strUnitName: String); /修改無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: 單位名稱 public Public declarations end; var frmCnfgPara: TfrmCnfgPara; implementation uses ufrmMaim, UCommon, uConst; $R *.DFM procedure TfrmCnfgPara.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmCnfgPara.FormDestroy(Sender: TObject); begin 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: FQuery.Free; frmCnfgPara := nil; end; procedure TfrmCnfgPara.BitBtn2Click(Sender: TObject); begin Close; end; procedure TfrmCnfgPara.FormShow(Sender: TObject); begin Sdgl.SetConnectString(adoCfngPara); if not adoCfngPara.Active then adoCfngPara.Open; if adoCfngPara.RecordCount = 1 then begin edtUnitName.Text := adoCfngPara.Fields0.AsString; maskPw.Text := adoCfngPara.Fields1.AsString; end; FQuery := TADOQuery.Create(Nil); Sdgl.SetConnectString(FQuery); 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: end; procedure TfrmCnfgPara.BitBtn1Click(Sender: TObject); var strInsert: String; OldUnitName: String; begin if (Trim(edtUnitName.Text) = ) or (Trim(maskPw.Text) = ) then begin /todo Sdgl.ShowErrMsg(請輸入單位名稱或密碼! ); edtUnitName.SetFocus; Exit; end; OldUnitName := Sdgl.CurUnitName; if OldUnitName Trim(edtUnitName.Text) then begin if MessageBox(Handle, PChar(DeleteAllData), 警告 , MB_OKCANCEL or MB_ICONWARNING) IDoK then Exit; end; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: /todo 是否有記錄 if adoCfngPara.RecordCount = 1 then begin strInsert := update CnfgPara set UseUnitName = + #39 + Trim(edtUnitName.Text) + #39 + , PassWd = + #39 + Trim(maskPw.Text) + #39; end else begin strInsert := Insert into CnfgPara values( + #39 + Trim(edtUnitName.Text) + #39 + , + #39 + Trim(maskPw.Text) + #39 + ); end; with adoCfngPara do begin Close; SQL.Clear; SQL.Text := strInsert; try 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: ExecSQL; Sdgl.ShowErrMsg(數(shù)據(jù)提交完成! ); frmCnfgPara.Close; except Sdgl.ShowErrMsg(提交數(shù)據(jù)出錯! ); Exit; end; end; if OldUnitName Trim(edtUnitName.Text) then /改變了使用單位的名稱 DeleteAllHistroyData; ModifyUnitName(Trim(edtUnitName.Text); /修改車間表中的單位名稱 end; procedure TfrmCnfgPara.edtUnitNameKeyPress(Sender: TObject; var Key: Char); begin if (key = #13) then if (Trim(edtUnitName.Text) ) then 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: maskPw.SetFocus else begin Sdgl.ShowErrMsg(請輸入單位名稱或密碼! ); end; end; procedure TfrmCnfgPara.maskPwKeyPress(Sender: TObject; var Key: Char); begin if key = #13 then if (Trim(edtUnitName.Text) ) and (Trim(maskPw.Text) ) then BitBtn1Click(Sender) else begin Sdgl.ShowErrMsg(請輸入單位名稱或密碼! ); edtUnitName.SetFocus; end; end; procedure TfrmCnfgPara.DeleteAllHistroyData; var strDelete: Array1.4 of String; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: I: Integer; begin FQuery := TADOQuery.Create(Nil); Sdgl.SetConnectString(FQuery); strDelete1 := delete from TakeMeter; strDelete2 := delete from Meter; strDelete3 := delete from Price; strDelete4 := delete from Workshop; with FQuery do begin for I := Low(strDelete) to High(strDelete) do begin Close; SQL.Clear; SQL.Text := strDeleteI; try ExecSQL; except / end; end; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: /Free; end; end; procedure TfrmCnfgPara.ModifyUnitName(strUnitName: String); var strUnitSQL: String; begin with FQuery do begin if Sdgl.CurUnitName = then strUnitSQL := insert into workshop values (+ 1, + #39+ strUnitName + #39 + ,0, + #39 + strUnitName+ #39 + ,0) else strUnitSQL := update workshop set WrokShopName = + #39 + strUnitName +#39; Close; SQL.Clear; SQL.Text := strUnitSQL; try ExecSQL; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: except / end; end; end; end. 3.3 類型維護界面與代碼設計實現(xiàn) 代碼設計 : unit ufrmMeter; interface 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, ExtCtrls, Grids, DBGridEh, StdCtrls, Buttons, Db, DBTables, ADODB, UCommon, DBCtrlsEh, Mask, DBLookupEh, DBCtrls, MyNavEh; type TfrmMeter = class(TForm) Panel1: TPanel; dsMeter: TDataSource; adoMeter: TADOQuery; Label23: TLabel; Label15: TLabel; Label21: TLabel; Label9: TLabel; Label8: TLabel; Label10: TLabel; DBLookupComboboxEh1: TDBLookupComboboxEh; DBEditEh9: TDBEditEh; DBLookupComboboxEh2: TDBLookupComboboxEh; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: DBEditEh16: TDBEditEh; DBLookupComboboxEh3: TDBLookupComboboxEh; DBEditEh14: TDBEditEh; Label4: TLabel; Label16: TLabel; Label5: TLabel; Label22: TLabel; Label11: TLabel; Label7: TLabel; DBEditEh11: TDBEditEh; DBLookupComboboxEh6: TDBLookupComboboxEh; DBEditEh7: TDBEditEh; DBEditEh1: TDBEditEh; DBEditEh6: TDBEditEh; DBGridEh3: TDBGridEh; MyDBNavigator1: TMyDBNavigator; DataSource1: TDataSource; ADOQuery1: TADOQuery; adoMeterMeterNO: TWideStringField; adoMeterMultiple: TIntegerField; adoMeterWorkShopID: TIntegerField; adoMeterPriceID: TIntegerField; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: adoMeterBaseNumber: TIntegerField; adoMeterMeterSort: TIntegerField; adoMeterType: TWideStringField; adoMeterSetupDate: TDateTimeField; adoMeterMaxBound: TIntegerField; adoMeterSubjoinNumber: TIntegerField; adoMeterFitPlace: TWideStringField; adoMeterSubWorkShopID: TSmallintField; adoMeterSubWorkShop: TStringField; adoMeterSubPrice: TStringField; adoMeterSubsubWorkShop: TStringField; adoMeterSortName: TStringField; DataSource2: TDataSource; ADOQuery2: TADOQuery; DataSource3: TDataSource; ADOQuery3: TADOQuery; DataSource4: TDataSource; ADOQuery4: TADOQuery; DBEditEh2: TDBEditEh; adoMeterQuota: TBCDField; Label1: TLabel; procedure FormClose(Sender: TObject; var Action: 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: TCloseAction); procedure FormDestroy(Sender: TObject); procedure FormCreate(Sender: TObject); procedure DBLookupComboboxEh3CloseUp(Sender: TObject; Accept: Boolean); procedure DBLookupComboboxEh2CloseUp(Sender: TObject; Accept: Boolean); private Private declarations public Public declarations end; var frmMeter: TfrmMeter; implementation $R *.DFM 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: procedure TfrmMeter.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmMeter.FormDestroy(Sender: TObject); begin adoMeter.Close; ADOQuery1.Free; ADOQuery2.Free; ADOQuery3.Free; ADOQuery4.Free; frmMeter := nil; end; procedure TfrmMeter.FormCreate(Sender: TObject); begin Sdgl.SetConnectString(adoMeter); Sdgl.SetConnectString(ADOQuery1); Sdgl.SetConnectString(ADOQuery2); 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: Sdgl.SetConnectString(ADOQuery3); Sdgl.SetConnectString(ADOQuery4); if not adoMeter.Active then adoMeter.Open; if not ADOQuery1.Active then ADOQuery1.Open; if not ADOQuery2.Active then ADOQuery2.Open; if not ADOQuery3.Active then ADOQuery3.Open; if not ADOQuery4.Active then ADOQuery4.Open; end; procedure TfrmMeter.DBLookupComboboxEh3CloseUp(Sender: TObject; Accept: Boolean); begin ADOQuery3.Close; ADOQuery3.Parameters.ParamByName(MeterSortID).Value := DBLookupComboboxEh3.KeyValue; ADOQuery3.Open; end; procedure TfrmMeter.DBLookupComboboxEh2CloseUp(Sender: TObject; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: Accept: Boolean); begin ADOQuery4.Close; ADOQuery4.Parameters.ParamByName(ResideWorkShop).Value := DBLookupComboboxEh2.KeyValue; ADOQuery4.Open; end; end. 3.4 抄表界面與代碼設計 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: unit ufrmMeter; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, ExtCtrls, Grids, DBGridEh, StdCtrls, Buttons, Db, DBTables, ADODB, UCommon, DBCtrlsEh, Mask, DBLookupEh, DBCtrls, MyNavEh; type TfrmMeter = class(TForm) 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: Panel1: TPanel; dsMeter: TDataSource; adoMeter: TADOQuery; Label23: TLabel; Label15: TLabel; Label21: TLabel; Label9: TLabel; Label8: TLabel; Label10: TLabel; DBLookupComboboxEh1: TDBLookupComboboxEh; DBEditEh9: TDBEditEh; DBLookupComboboxEh2: TDBLookupComboboxEh; DBEditEh16: TDBEditEh; DBLookupComboboxEh3: TDBLookupComboboxEh; DBEditEh14: TDBEditEh; Label4: TLabel; Label16: TLabel; Label5: TLabel; Label22: TLabel; Label11: TLabel; Label7: TLabel; DBEditEh11: TDBEditEh; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: DBLookupComboboxEh6: TDBLookupComboboxEh; DBEditEh7: TDBEditEh; DBEditEh1: TDBEditEh; DBEditEh6: TDBEditEh; DBGridEh3: TDBGridEh; MyDBNavigator1: TMyDBNavigator; DataSource1: TDataSource; ADOQuery1: TADOQuery; adoMeterMeterNO: TWideStringField; adoMeterMultiple: TIntegerField; adoMeterWorkShopID: TIntegerField; adoMeterPriceID: TIntegerField; adoMeterBaseNumber: TIntegerField; adoMeterMeterSort: TIntegerField; adoMeterType: TWideStringField; adoMeterSetupDate: TDateTimeField; adoMeterMaxBound: TIntegerField; adoMeterSubjoinNumber: TIntegerField; adoMeterFitPlace: TWideStringField; adoMeterSubWorkShopID: TSmallintField; adoMeterSubWorkShop: TStringField; adoMeterSubPrice: TStringField; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: adoMeterSubsubWorkShop: TStringField; adoMeterSortName: TStringField; DataSource2: TDataSource; ADOQuery2: TADOQuery; DataSource3: TDataSource; ADOQuery3: TADOQuery; DataSource4: TDataSource; ADOQuery4: TADOQuery; DBEditEh2: TDBEditEh; adoMeterQuota: TBCDField; Label1: TLabel; procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure FormDestroy(Sender: TObject); procedure FormCreate(Sender: TObject); procedure DBLookupComboboxEh3CloseUp(Sender: TObject; Accept: Boolean); procedure DBLookupComboboxEh2CloseUp(Sender: TObject; Accept: Boolean); private Private declarations 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: public Public declarations end; var frmMeter: TfrmMeter; implementation $R *.DFM procedure TfrmMeter.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; procedure TfrmMeter.FormDestroy(Sender: TObject); begin adoMeter.Close; ADOQuery1.Free; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: ADOQuery2.Free; ADOQuery3.Free; ADOQuery4.Free; frmMeter := nil; end; procedure TfrmMeter.FormCreate(Sender: TObject); begin Sdgl.SetConnectString(adoMeter); Sdgl.SetConnectString(ADOQuery1); Sdgl.SetConnectString(ADOQuery2); Sdgl.SetConnectString(ADOQuery3); Sdgl.SetConnectString(ADOQuery4); if not adoMeter.Active then adoMeter.Open; if not ADOQuery1.Active then ADOQuery1.Open; if not ADOQuery2.Active then ADOQuery2.Open; if not ADOQuery3.Active then ADOQuery3.Open; if not ADOQuery4.Active then ADOQuery4.Open; end; 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: procedure TfrmMeter.DBLookupComboboxEh3CloseUp(Sender: TObject; Accept: Boolean); begin ADOQuery3.Close; ADOQuery3.Parameters.ParamByName(MeterSortID).Value := DBLookupComboboxEh3.KeyValue; ADOQuery3.Open; end; procedure TfrmMeter.DBLookupComboboxEh2CloseUp(Sender: TObject; Accept: Boolean); begin ADOQuery4.Close; ADOQuery4.Parameters.ParamByName(ResideWorkShop).Value := DBLookupComboboxEh2.KeyValue; ADOQuery4.Open; end; end. 無憂無慮畢設網(wǎng) ():畢業(yè)設計源碼下載 畢業(yè)設計源碼下載: www.5156b
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025版彩鋼棚防火安全檢測與整改服務合同
- 二零二五年度并購交易保密協(xié)議起草要點與法律適用
- 2025版責任保險合同履行標準及全面擔保承諾書
- 二零二五年度奧迪A3L購入與車輛改裝合同
- 2025年度新能源汽車融資租賃合同示范文本
- 風電土壤壓實效應-洞察及研究
- 二零二五版智能交通信號設備采購合同書
- 二零二五版“全球奢侈品銷售合同”英文翻譯
- 2025年膩子行業(yè)市場調(diào)研與分析服務合同
- 2025年度安防產(chǎn)品及技術培訓與認證合同
- GB/T 15684-2015谷物碾磨制品脂肪酸值的測定
- 百靈達x32數(shù)字調(diào)音臺說明書簡體中文
- GA/T 947.2-2015單警執(zhí)法視音頻記錄系統(tǒng)第2部分:執(zhí)法記錄儀
- 職業(yè)技能培訓鑒定教材編寫規(guī)定
- 噴霧干燥器課程設計終稿
- 2023年濰坊市交通投資有限公司招聘筆試題庫及答案解析
- 住院醫(yī)師規(guī)范化培訓小講課教學設計課件
- 酸化土壤改良技術規(guī)范DB50-T 1146-2021
- 英威騰GD變頻器調(diào)試說明
- 季節(jié)性施工專項施工方案(常用)
- 倉庫作業(yè)指導書
評論
0/150
提交評論