毕业设计(论文)DELPHI 水电管理系统(附源程序).doc

上传人:土8路 文档编号:10232027 上传时间:2021-05-01 格式:DOC 页数:62 大小:236.50KB
返回 下载 相关 举报
毕业设计(论文)DELPHI 水电管理系统(附源程序).doc_第1页
第1页 / 共62页
毕业设计(论文)DELPHI 水电管理系统(附源程序).doc_第2页
第2页 / 共62页
毕业设计(论文)DELPHI 水电管理系统(附源程序).doc_第3页
第3页 / 共62页
毕业设计(论文)DELPHI 水电管理系统(附源程序).doc_第4页
第4页 / 共62页
毕业设计(论文)DELPHI 水电管理系统(附源程序).doc_第5页
第5页 / 共62页
点击查看更多>>
资源描述

《毕业设计(论文)DELPHI 水电管理系统(附源程序).doc》由会员分享,可在线阅读,更多相关《毕业设计(论文)DELPHI 水电管理系统(附源程序).doc(62页珍藏版)》请在三一文库上搜索。

1、全套源程序,联系全套源程序,联系 153893706 毕业设计毕业设计 院系院系_ 专业专业_ 班级班级_ 姓名姓名_ 日期日期 年年 月月 日日 中文摘要中文摘要 水电管理系统为水电收费管理人员日常工作的抄表,报 表生成,费用计算等提供充足的信息和快捷的查询手段.其开 发内容主要包括后台数据库的建立和维护以及前端应用程 序的开发两个方面。利用 DELPHI 6.0 软件及其提供的各种 面向对象的开发工具,建立完整性强、安全性好的数据库, 开发出功能完备,易使用的应用程序。经过调试、编译与 实现,该程序界面友好、程序设计风格朴素,使用起来美 观大方、方便易用。尤其是系统的“报表生成模块”的功

2、能极大的减轻工作人员的工作量,并以快速、准确等优点 取代人工操作,提高了水电管理工作效率。 关键词关键词 : DELPHI 6.0 信息管理系统信息管理系统 数据库数据库 模模 块块 水电管理系统水电管理系统 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 enquirie

3、s. 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, e

4、asy 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 r

5、apid, accurate, and other advantages replace manually operated, and enhanced power management efficiency. Keyword : Delphi 6.0 Information Management System database module utilities management system 引引 言言 1 1 Delphi 语言概述语言概述2 1.1 Delphi 简介简介 2 1.2 数据库系统简介数据库系统简介 5 1.3 本应用软件的基本介绍本应用软件的基本介绍 7 2 本应用程

6、序的构成和开发步骤本应用程序的构成和开发步骤9 2.1 可行性研究可行性研究10 2.1.1 经济可行性经济可行性11 2.1.2 时间可行性时间可行性12 2.1.3 技术可行性技术可行性13 2.1.4 社会可行性社会可行性14 2.2 数据库的建立和连接数据库的建立和连接15 2.3 系统的总体设计系统的总体设计 17 2.4 系统的详细设计系统的详细设计 19 3 本程序的技术实现及具体功能本程序的技术实现及具体功能 21 3.1 登录的界面与程序设计实现登录的界面与程序设计实现24 3.2 系统参数配置界面与代码设计实现系统参数配置界面与代码设计实现34 3.3 类型维护界面与代码设

7、计实现类型维护界面与代码设计实现 45 3.4 抄表界面与代码设计抄表界面与代码设计 52 3.5 报表管理界面设计与代码设计报表管理界面设计与代码设计 55 结结 论论 60 致致 谢谢 61 参参 考考 文文 献献62 引引 言言 随着经济的发展,社会的进步,计算机越来越深入到我们日常 的工作学习及生活中,成为我们日常生活中不可缺少的辅助工具。 随着科学技术的不断提高,计算机科学日渐成熟,其强大的功能已为 人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的 作用。它已经深入到日常工作和生活的方方面面,比如文字处理、 信息管理、辅助设计、图形图像处理、教育培训以及游戏娱乐等。 各行

8、各业的人们无须经过特别的训练就能够使用电脑完成许许多多 复杂的工作。然而,虽然现在世界上已经充满了多如牛毛的各种软 件,但它们依然不能满足用户的各种特殊需要,人们还不得不开发 适合自己特殊需求的软件。以前开发 Windows 应用软件是专业人员 的工作,需要掌握许多专业知识和经过特殊的培训才能胜任。现在 不同了,即使你没有接受过严格的程序设计训练,使用Delphi 编 程语言也一样能够开发出功能强大、适合自己特殊需求的应用程序 了。Delphi 编程语言继承了其他语言易学易用的特点,特别适合 于初学者学习 Windows 系统编程。 水电管理系统用计算机管理水电收费管理人员收取辖区内用户 费用

9、的一种计算机应用技术的创新,在计算机还未普及之前水电收费 管理都是由工作人员人工书写,调阅的方式来操作的.现在一般的水 电管理都采用计算机智能化管理,采用计算机作为工具的实用的计算 机网络化管理程序来帮助前台管理员进行更有效的水电管理工作。 水电管理系统是典型的信息管理系统(MIS),其开发主要包括后台数 据库的建立和维护以及前端应用程序的开发两个方面。对于前者要 求建立起数据一致性和完整性强、数据安全性好的库。而对于后者 则要求应用程序功能完备,易使用等特点。 经过分析,我们使用 Delphi 编程语言开发工具,利用其提供 的各种面向对象的开发工具,尤其是数据窗口这一能方便而简洁操纵 数据库

10、的智能化对象,首先在短时间内建立系统应用原型,然后,对初 始原型系统进行需求迭代,不断修正和改进,直到形成用户满意的可 行系统。 因为本人能力有限,加上时间紧迫,所以设计出来的本系统可 能功能比较简单,另外本系统是单机版,不能实现网络互联操作,这 些都有待于我在以后的工作学习中进一步改进。 1.1Delphi 简介简介 1.11.1 DelphiDelphi 简介简介 Delphi 是 Inprise 公司出品的一个优秀的可视化程序开 发工具软件,它短小精悍,但功能却可以与庞大的 visual c+媲美。它易学易用,如同 VB,因而被称为“第四代编 程语言” 。 从 1995 年推出 Delp

11、hi1.0 至今已经经历了 7 个版本, Delphi7.0 运行在 win9x 或 winme,win2000,winxp,windowsNT 等操作系统下,是一 个 32 位的应用程序开发工具。这里把“VB”比作是傻瓜相 机,Delphi 是带有自动功能的专业相机。前些年,软件界 流行一句话叫“真正的程序员用 VC,聪明的程序员用 Delphi” 。也有的把 Delphi 称作 VB 杀手。 1.21.2 数据库系统简介数据库系统简介 数据库系统是一个实际可运行的存储、维护和应用系 统提供数据的软件系统,是存储介质、处理对象和管理系 统的集合体。它通常由软件、数据库和数据管理员组成。 其软

12、件主要包括操作系统、各种宿主语言,实用程序以及 数据库管理系统。数据库是依照某种数据模型组织起来并 存放二级存储器中的数据集合。这些数据为多个应用服务, 独立于具体的应用程序。数据库由数据库管理系统统一管 理,数据的插入、修改和检索均要通过数据库管理系统进 行。数据库管理系统是一种系统软件,它的主要功能是维 护数据库并有效地访问数据库中任意部分数据。对数据库 的维护包括保持数据的完整性、一致性和安全性。数据管 理员负责创建、监控和维护整个数据库,使数据能被任何 有权使用的人有效使用。数据库管理员一般是由业务水平 较高、资历较深的人员担任。 数据库系统的个体含义是指一个具体的数据库管理系 统软件

13、和用它建立起来的数据库;它的学科含义是指研究、 开发、建立、维护和应用数据库系统所涉及的理论、方法、 技术所构成的学科。在这一含义下,数据库系统是软件研 究领域的一个重要分支,常称为数据库领域。 数据库研究跨越于计算机应用、系统软件和理论三个 领域,其中应用促进新系统的研制开发,新系统带来新的 理论研究,而理论研究又对前两个领域起着指导作用。数 据库系统的出现是计算机应用的一个里程碑,它使得计算 机应用从以科学计算为主转向以数据处理为主,并从而使 计算机得以在各行各业乃至家庭普遍使用。在它之前的文 件系统虽然也能处理持久数据,但是文件系统不提供对任 意部分数据的快速访问,而这对数据量不断增大的

14、应用来 说是至关重要的。为了实现对任意部分数据的快速访问, 就要研究许多优化技术。这些优化技术往往很复杂,是普 通用户难以实现的,所以就由系统软件(数据库管理系统) 来完成,而提供给用户的是简单易用的数据库语言。由于 对数据库的操作都由数据库管理系统完成,所以数据库就 可以独立于具体的应用程序而存在,从而数据库又可以为 多个用户所共享。因此,数据的独立性和共享性是数据库 系统的重要特征。数据共享节省了大量人力物力,为数据 库系统的广泛应用奠定了基础。数据库系统的出现使得普 通用户能够方便地将日常数据存入计算机并在需要的时候 快速访问它们,从而使的计算机走出科研机构进入各行各 业、进入家庭。 1

15、.31.3 本应用软件的基本介绍本应用软件的基本介绍 本应用软件先是打开一个启动窗口,就可以进入应用 程序的主窗口了。主界面是一个图型界面窗口,整个平台 显示采用人性化方式,可以非常方便的系统管理、字典维 护、抄表,报表管理等基本信息,管理日常经营的基本情况, 通过各种条件查询出水电管理的基本信息,以及打印出查 询出的基本信息,总之一切水电管理基本信息都会显示在 系统平台上,大大提高了管理人员的工作效率。 2 2本应用程序的构成和开发步骤本应用程序的构成和开发步骤 下面从软件工程的角度介绍本程序的基本开发步骤。 Delphi 应用程序一般包含以下三个基本部分: 应用程序运行的接口:负责系统整体

16、环境的设置,运 行状态的监视,应用程序的启动等。 应用程序的主体:主要完成用户的业务逻辑功能,如 系统参数配置,字典维护,抄表,报表生成.等信息. 应用程序的辅助部分:协助程序主体完成的一些工作。 下面从软件工程的角度描述本程序的开发生命周期,开 发过程和组织过程。 2.12.1 可行性研究可行性研究 任何一个系统或一项工程,在建立之前,必须首选进 行可行性分析,可行性分析包括两层含义,一是可能性, 二是必要性。可能性指开发信息系统的条件是否具备,必 要性是指客观上是否真正需要,通过可行性研究,可避免 盲目投资,减少政治性要的损失。下面从四方面来讨论: 2.1.1 经济可行性 主要是只指算一个

17、新的系统开发所需要的投资费用和 运算费用,并与估计的新系统收益进行比较,看是否有利。 本系统所需的软硬件成本比较低,投资小,具有一定的通 过性,因此 ,在经济上是可行的。 2.1.2 时间可行性 主要包括系统在目前环境下能否正常运行,运行后所 引起的各方面,以及这些变化对社会或人的因素所产生的 影响。本系统对人事的管理比较全面,可长期使用。 2.1.3 技术可行性 利用现有的设备,软件及技术人员,新系统的目标能 否达到,这也是可行性研究中需要考虑的一个问题。关系 型数据库的高速发展使管理信息系统具备了良好的开发环 境。本系统使用的 Delphi 普及性好,操作简单,用户可以 很快掌握使用方法,

18、因此,在技术上是完全可行的。 2.1.4 社会可行性 人类社会文明的发展已进入信息化的高速发展时期,传 统的手工方式支持下的管理模式,已经不能满足各方面的 需要。开发本系统的目标不仅是提高工作效率,减轻劳动 强度,而且减少出错率,具有很好的社会意义。 2.22.2 数据库的建立和连接数据库的建立和连接 这个程序采用的数据库是 Microsoft Access2000,Delphi 作为数据库的前台开发工具,必须与后 台数据库进行连接,这样才能控制和进行操作数据库,数 据库的连接方式有两种,ODBC 和 ADO。 ODBC 是数据库的通用接口,其缺点是效率低;专用 接口调用直接速度快,但是通用性

19、差,如果用 ODBC 连接 数据库一般要两个步骤:1.要创建数据源;2.创建描述文件。 数据库的建立则时在 access2000 中建立的,在这里你可以 设置数据库的密码,对数据库进行保护。在创建数据源时 可以通过 BDE administrator 进行创建,也可以通过系统控 制面板中的 ODBC 数据源进行建立。而描述文件则可以在 Delphi 的主程序中用 Database Profile 中进行建立,之后进 行数据库的连接。接下来的工作是建表。同样建表的过程 也不是唯一的,但是最终实现的结果是唯一的。你可以通 过 Access 进行建表,也可以通过在 Visual Basic 主程序中

20、 建表,也可以通过 powerdesigner 进行可视化的建立,不过 用这种方法,在导入的时候要把数据库要先断开,否则数 据库的数据容易丢失。建表的过程注意规范化命名规则, 如表的字段名等等。同时也要注意表的字段长度和可否为 空。因为以后要设计到主键,外键的问题。如果字段名不 同,同一字段长度不同则主键和外键将会连接不上。可见 建表时应做好全局的打算。我在程序开发的初期,同样犯 了这个错误,导致数据库出错,有时还要向表中新加入字 段。导致数据窗口不好用的连锁反映。 2.32.3 系统的总体设计系统的总体设计 这个管理系统从 4 月 1 日开始着手设计开发,经过一段 时间的分析,并根据对水电管

21、理的具体要求及需要本软件 实现的功能,将本软件分为 5 个大的模块,分别是:第一 部分:系统管理;第二部分:字典维护;第三部分:抄表; 第四部分:报表管理。 程序流程图如下: 程序登陆 主界面 系 统 管 理 字典 维护 抄表 报表 管理 2.4系统的详细设计系统的详细设计 进入 Access 后要做的第一件事就是建立一个数据库。 Access 提供了 6 种用构造数据库系统的对象,根据本课题 的需要,在这里选择一个空的数据库,命名建立了一个数 据库名称为“SDManager” ,水电管理系统。并在此数据库 下创建了六个表,用于存放原始数据。它只是存放数据, 对其中数据的修改要通过对应的窗体来

22、完成。创建各表的 具体结构如下: fgpara 信息表 2.meter 信息表 3.metersort 信息表 4.price 信息表 5.takemeter 信息表 6.车间信息表 3 本程序的技术实现及具体功能本程序的技术实现及具体功能 3.1登录的界面与程序设计实现登录的界面与程序设计实现 代码设计: unit uLogin; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, Buttons, Db, ADODB; type TfrmLogi

23、n = class(TForm) Label1: TLabel; 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(Sen

24、der: TObject); procedure BitBtn1Click(Sender: TObject); private Private declarations Function GetPassWd: String; public Public declarations IsOk: Boolean; iTime: Integer; /计算登录次数 end; var frmLogin: TfrmLogin; implementation uses UCommon, uConst; $R *.DFM procedure TfrmLogin.FormCreate(Sender: TObjec

25、t); begin ADOQuery1.ConnectionString := Format(strConnectString, ExtractFilePath(Application.ExeName); if not FileExists(ExtractFilePath(Application.ExeName) + MDBSDManager.mdb) then Begin MessageBox(Handle, 数据库文件不存在!, 错误, MB_OK or MB_ICONERROR); Application.Terminate; end else begin Try ADOQuery1.C

26、onnection; 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 :=

27、caFree; end; procedure TfrmLogin.FormDestroy(Sender: TObject); begin frmLogin := nil; 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, 你无权使用本系统!, 提示, MB_OK or MB_

28、ICONINFORMATION); Application.Terminate; end; MessageBox(Handle, 输入的密码不正确,请确认!, 登录提示, MB_OK or MB_ICONINFORMATION); Edit1.SetFocus; IsOk := False; Inc(iTime); end else begin IsOk := True; frmLogin.Close; end; end; function TfrmLogin.GetPassWd: String; begin /todo if not ADOQuery1.Active then ADOQuer

29、y1.Open; Result := ADOQuery1.Fields0.AsString; end; end. 3.2系统参数配置界面与代码设计实现系统参数配置界面与代码设计实现 代码设计: unit ufrmCnfgPara; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, Mask, Buttons, Db, ADODB, ExtCtrls; type TfrmCnfgPara = class(TForm) Label1: TLabel;

30、edtUnitName: TEdit; 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);

31、 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; /删除 所有的历史数据 Procedur

32、e ModifyUnitName(strUnitName: String); /修改 单位名称 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.Form

33、Destroy(Sender: TObject); begin 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.Re

34、cordCount = 1 then begin edtUnitName.Text := adoCfngPara.Fields0.AsString; maskPw.Text := adoCfngPara.Fields1.AsString; end; FQuery := TADOQuery.Create(Nil); Sdgl.SetConnectString(FQuery); end; procedure TfrmCnfgPara.BitBtn1Click(Sender: TObject); var strInsert: String; OldUnitName: String; begin if

35、 (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

36、 then Exit; end; /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 + , +

37、 #39 + Trim(maskPw.Text) + #39 + ); end; with adoCfngPara do begin Close; SQL.Clear; SQL.Text := strInsert; try ExecSQL; Sdgl.ShowErrMsg(数据提交完成!); frmCnfgPara.Close; except Sdgl.ShowErrMsg(提交数据出错!); Exit; end; end; if OldUnitName Trim(edtUnitName.Text) then /改变了使 用单位的名称 DeleteAllHistroyData; ModifyU

38、nitName(Trim(edtUnitName.Text); /修改车间表中 的单位名称 end; procedure TfrmCnfgPara.edtUnitNameKeyPress(Sender: TObject; var Key: Char); begin if (key = #13) then if (Trim(edtUnitName.Text) ) then maskPw.SetFocus else begin Sdgl.ShowErrMsg(请输入单位名称或密码!); end; end; procedure TfrmCnfgPara.maskPwKeyPress(Sender:

39、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; I: Integer; begin

40、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.Te

41、xt := strDeleteI; try ExecSQL; except / end; end; /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 + strUnitN

42、ame+ #39 + ,0) else strUnitSQL := update workshop set WrokShopName = + #39 + strUnitName +#39; Close; SQL.Clear; SQL.Text := strUnitSQL; try ExecSQL; except / end; end; end; end. 3.3类型维护界面与代码设计实现类型维护界面与代码设计实现 代码设计: unit ufrmMeter; interface uses Windows, Messages, SysUtils, Classes, Graphics, Contro

43、ls, 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; L

44、abel8: TLabel; Label10: TLabel; DBLookupComboboxEh1: TDBLookupComboboxEh; DBEditEh9: TDBEditEh; DBLookupComboboxEh2: TDBLookupComboboxEh; DBEditEh16: TDBEditEh; DBLookupComboboxEh3: TDBLookupComboboxEh; DBEditEh14: TDBEditEh; Label4: TLabel; Label16: TLabel; Label5: TLabel; Label22: TLabel; Label11:

45、 TLabel; Label7: TLabel; DBEditEh11: TDBEditEh; DBLookupComboboxEh6: TDBLookupComboboxEh; DBEditEh7: TDBEditEh; DBEditEh1: TDBEditEh; DBEditEh6: TDBEditEh; DBGridEh3: TDBGridEh; MyDBNavigator1: TMyDBNavigator; DataSource1: TDataSource; ADOQuery1: TADOQuery; adoMeterMeterNO: TWideStringField; adoMete

46、rMultiple: TIntegerField; adoMeterWorkShopID: TIntegerField; adoMeterPriceID: TIntegerField; adoMeterBaseNumber: TIntegerField; adoMeterMeterSort: TIntegerField; adoMeterType: TWideStringField; adoMeterSetupDate: TDateTimeField; adoMeterMaxBound: TIntegerField; adoMeterSubjoinNumber: TIntegerField;

47、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: TCloseAction); procedure FormDestroy(Sender: TObject); procedure FormCreate(Sender: TObject

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 社会民生


经营许可证编号:宁ICP备18001539号-1