《毕业设计(论文)VB高速公路票据管理系统实现与设计.doc》由会员分享,可在线阅读,更多相关《毕业设计(论文)VB高速公路票据管理系统实现与设计.doc(52页珍藏版)》请在三一办公上搜索。
1、毕业设计高速公路票据管理系统摘 要3Abstract3第一章 引言411 课题背景412 系统简介51. 3 开发软件介绍第二章 系统的分析621 系统开发的目标和思想622 系统的可行性分析8第三章 系统的设计1831 系统的功能结构设计1832 系统的数据库设计33 界面设计与代码设计2324结束语46致谢47参考文献52 摘 要 高速公路票据管理系统用计算机管理高速公路车辆收费并记录的一种计算机应用技术的创新,在计算机还未普及之前公路收费开票据都是由工作人员手工书写的方式来操作的.现在一般的告诉公路收费管理站都是采用计算机作为工具的实用的计算机公路票据管理程序来帮助管理员进行更有效的车辆
2、收费工作。公路票据管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。 经过分析,我们使用 MICROSOFT公司的 VISUAL BASIC开发工具,利用其提供的各种面向对象的开发工具,尤其是数据窗口这一能方便而简洁操纵数据库的智能化对象,首先在短时间内建立系统应用原型,然后,对初始原型系统进行需求迭代,不断修正和改进,直到形成用户满意的可行系统。关键字:中介管理,MIS,visual basic ,数据库AbstractNotes
3、 highway management systems using computers and records management fees highway vehicles a computer application technology innovation, road toll has not yet universal in the computer before the bills are written by the staff manual to operate. The general told the road charges are used computer as a
4、 tool for the management of the computer highway bills practical management procedures to help managers more effective vehicle charges. Highway Bills management system is a typical management information system (MIS), including its main development background to the establishment and maintenance of
5、the database and front-end application development 2. The request for the establishment of strong data consistency and integrity, good for the security of the data. For the latter request applications functions, such as easy to use features. After analysis, we use Microsoft visual basic development
6、tool companies, the use of its various object-oriented development tools, especially data that can be easily accessible and concise window manipulation database intelligent objects, the first prototype application system in a short time and then, computation of the initial prototype system needs to
7、constantly revise and improve until the formation of a viable system of user satisfaction. keyword : intermediary management MIS,visual basic database第一章 引言11 课题背景高速公路票据管理系统用计算机管理高速公路车辆收费并记录的一种计算机应用技术的创新,在计算机还未普及之前公路收费开票据都是由工作人员手工书写的方式来操作的.现在一般的告诉公路收费管理站都是采用计算机作为工具的实用的计算机公路票据管理程序来帮助管理员进行更有效的车辆收费工作。公
8、路票据管理系统是典型的信息管理系统(MIS),其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。12 系统简介本系统服务于高速公路收费站的工作人员,方便日常工作的收费,开票之需要,本系统只要由以下几大功能模块构成.一.数据操作:输入数据,退出二.查询:记录查询三.用户管理:添加用户,收费员管理四.修改密码:五.视窗:工具栏,状态栏六.窗口:层叠,横向平铺,纵向平铺七.帮助:关于1. 3 开发软件介绍Visual Basic 6.0是Micrsoft公司出品的开发工具,Vi
9、sual Basic是一种可视化的,面向对象的Windows开发语言,它具有易用,通用和开发效率高的特点。随着微软对它不断地改进以及计算机本身性能的提高,使得Visual Basic越来越适合一般的应用程序开发。正如Bill Gate所说,世界上绝大多数的Windows应用程序是用Visual Basic编写的。在众多的开发工具中,我们为什么要选择Visual Basic6.0呢?因为VB具有众多其它开发工具所没有的优点!具体介绍如下:u 开发的高效u 语言的高效u 编译的高效u 执行的高效u 维护的高效基于以上理由,我们毫不忧郁的选择了VB6.0做为我们的开发工具!主要的控件及其基本属性,事
10、件简介u 命令按钮类的控件:1) Caption属性:用来显示在控件上的标题。2) Enable属性:控制控件的激活状态灰色或可用。3) Appearance属性:值为1时,则以3D效果显示该控件,0则不然。4) Backcolor属性:用来改变在按钮上显示图像的背景色。5) Cancel属性:该属性决定按钮是否为一个”取消”按钮。6) Default属性:决定哪一个命令按钮控件是窗体的缺省命令按钮.7) Font属性:控制各种文字字体类型.8) Left,top,height,width属性:设定控件的位置与大小.9) Style,picture属性:决定按钮的显示方式是否为图像形式出现.1
11、0) Visible属性:确定控件运行时是否为可见.11) Index属性:当控件为一控件数组时,此属性值为该控件在数组的下标值.12) DownPicture属性:设置/返回一个对图片的引用,该图片在按钮被单击处于压下状态时显示。13) DisabledPicture属性:设置/返回一个对图片的引用,该图片在控件无效时显示在控件中。14) MaskColor属性:设置/返回一个在按钮的图片中作为“掩码“的的颜色15) Picture属性:设置返回commandButton控件中要显示的图片。u 命令按钮类的事件:1) 单击事件Click事件(1) 触发与适用此事件是在一个命令按钮对象上按下然
12、后释放一个鼠标按钮时发生。命令按钮的Click事件仅对当单击鼠标时发生。(2) 事件处理过程按钮单击事件的处理过程为: Private Sub object-Click(Index As Integer)其中Object为引发该事件的对象名称。如果是命令按钮的控件是数组,则需要使用Index参数标识该控件。2) 获得焦点GotFocus事件(1) 触发与适用 当命令按钮获得焦点产生该事件,获得焦点可以通过诸如Tab切换或单击对象之类的用户动作,或在代码中用SetFocus方法改变焦点来实现。(2) 事件处理过程命令按钮GotFoucs事件处理过程为:Private Sub Object-Got
13、Focus(Index As Integer)3) LostFocus事件:当一个对象失去焦点时发生4) KeyDown事件:当命令按钮具有焦点时按下一个键时发生5) KeyUp事件:当命令按钮具有焦点时释放一个键时发生。6) KeyPress事件:当用户按下或松开一个ANSI键时发生。7) MouseDown事件:当在命令按钮上按下鼠标按钮时发生。8) MouseMove事件:当命令按钮上移动鼠标时发生。9) MouseUp事件:当在命令按钮上释放鼠标按钮时发生。 u 标签框类的控件类的控件:1) Caption属性:在应用程序界面上加入说明。2) Autosize属性:决定控件是否自动改变
14、大小以显示其全部内容。3) Backstyle属性:用以指示标签是否透明.4) Bordstyle属性:用以设定控件是否有边框。u 文本框类的控件:1) Text属性:通过像text属性赋值的方法来改变该属性的值。2) Maxlength属性:该属性设定在文本框控件中能够输入的最大字符数。3) Multline属性:该属性设定text字符串中是否接受换行符。4) Scrollbars属性:该属性决定是否为文本框加滚动条。5) Passwordchar属性:该属性设定输入文本的特殊显示字符,在设计密码程序时非常有用。6) Change事件属性:文本框的内容发生改变时,相应的控件之间发生相应的改变
15、,具有即时性。7) Keypress:事件由用户在文本框控件中按任意键触发。8) Alignment属性:设定控件中的文本对其方式9) Appearance属性:设定一个对象在运行时是否可以3D效果显示。10) BackColor属性:设置返回背景色11) BorderStyle属性:设置对象的边框样式12) DataField属性:设定数据使用者将被绑定到的字段名13) DataFormat属性:设定DataFormat对象,用于数据绑定14) DataMember属性:从数据供应程序提供的几个数据成员中返回/设定一个特定的数据成员15) DataSource属性:设定控件绑定的一个数据源1
16、6) DragIcon属性:设定图标,它将在拖放操作中作为指针显示17) DragMode模式:设定一个值,确定在拖放操作中所用方式18) Enabled属性:设置/返回运行时TextBox是否相应用户事件19) Font属性:设置/返回字体属性20) ForeColor属性:设置/返回文本的前景色21) Height属性:设置/返回TextBox的高度22) IMEMode属性:设置/返回数值用来确定输入方法编辑器的状态23) Index属性:设置/返回唯一的标识控件数组中该控件的编号24) Left属性:设置/返回TextBox控件的水平位置25) Locked属性:设置/返回TextBo
17、x中文本是否可编辑26) LinkItem属性:设置/返回DDE与另一个应用程序会话时,传给接受端的数据27) MaxLength属性:设置/返回一个值,指定在TextBox控件中能够输入的字符最大值28) MouseIcon属性:设置/返回自定义鼠标的图标29) Top属性:设置/返回TextBox控件的垂直位置30) Tag属性:存储过程所需的附加数据u 文本框类的事件:1) Change事件:当改变文本框内容时发生2) Click事件:鼠标单击控件时发生3) DblClick事件:用鼠标左键双击控件时发生4) DragDrop事件:在一个完整的拖放动作完成或使用Drag方法,并将其Act
18、ion参数设置为2时发生5) DragOver事件:在拖放操作正在进行时发生6) GotFocus事件:当一个命令按钮获得焦点时发生7) LinkClose事件:当一个DDE对话结束时发生8) LinkError事件:当一个DDE对话框过程中出现错误时,该事件发生9) KeyDown事件:当命令按钮具有焦点时按下一个键时发生10) Validate事件:在焦点转换到另一个控件之前发生,此时该控件的Causes Validation 属性值设置为True u 单选按钮类的控件:1) Caption属性:显示在控件上的文本,是单选按钮的标题。2) Alignment属性:决定单选按钮的标题在控件上
19、的位置。3) Enable属性:该控件为灰色时为false,表示运行时不可用。4) Index属性:属性值表示为单选按钮组成的控件中某个按钮的索引值。5) Tabindex属性:建立控件时,vb自动为其分配一个tabindex值,利用tab键可以在控件之间切换焦点。6) Value属性:反映控件状态的属性,返回true表示已选择了该按钮。7) Appearance 属性:设置/返回一个对象在运行时是否以3D效果显示。8) BackColor 属性:设置/返回背景色。9) Container 属性:设置/返回Form上的控件属性。10) DataField 属性:设置/返回数据使用者将被绑定到的
20、字段名。11) DataFormat 属性:设置/返回DataFormat对象,一个绑定对象将附加到它。12) DisabledPicture 属性:设置/返回一个对图像的引用,该图片在控件无效时显示在控件中。13) DownPicture 属性:设置/返回一个对图片的引用,该图片在控件单击下处于压下状态时显示。14) DragMode 属性:设置/返回一个值,确定在拖放操作中所用的方式。15) Font 属性:设置/返回字体属性。16) FontBold 属性:设置/返回字体粗体样式。17) FontItalic 属性:设置/返回字体斜体样式。 18) FontStrikethru 属性:设
21、置/返回字体删除线样式。19) FontUnderLine 属性:设置/返回字体下划线样式。20) FontName 属性:设置/返回控件中显示文本所用的字体大小。21) FontSize 属性:设置/返回控件中显示文本所用的字体大小22) Height 属性:设置/返回控件的高度。23) MaskColor 属性:设置/返回一个在控件的图片中作为掩码的颜色。24) MousePointer 属性:设置/返回一个值,该值指示在运行时当鼠标移动到对象上时显示的指针类型。u 单选按钮类的常用事件:1) Click 事件:鼠标单击控件时发生。2) DbClick事件: 当在一个对象上按下和释放鼠标按
22、钮并再次按下和释放按钮时,该事件发生。3) DragDrop事件:在一个完整的拖放动作或使用Drag方法,并将其Action参数设置位2时,该事件发生。4) DragOver事件: 在拖放操作正在进行时发生。5) GotFocus事件: 当获的对象焦点时发生。6) LostFocus事件:当对象失去焦点时发生。7) KeyDown事件:当控件具有焦点时按下一个键时发生。8) KeyUp事件: 当控件具有焦点时释放一个键时发生。9) KeyPress事件:当用户按下或释放ANSI一个键时发生。10) MouseDown事件:当在控件上按下鼠标键时发生。11) MouseMove事件:在控件上移动
23、鼠标时发生。12) MouseUp事件:在控件上释放鼠标时发生。u 复选按钮类的控件:1) Caption属性:缺省为check1。2) Index属性:该属性值为复选框控件数组的下标.3) Value属性:value为0表空白,为1表勾号,为2表示灰色勾号.4) Container属性:Form控件上的容器。5) DataChangeed属性:设置/返回一个值,指出被绑定的控件中的数据已经被某进程修改。6) DataField属性:设置或返回数据使用者将被绑定到的字段名。7) DataFormat 属性:设置或返回DataFormat对象,用于数据绑定。8) Datasource属性:设置或
24、返回控件绑定的一个数据源。9) DisabledPicture属性:设置或返回一个对图片的引用,该图片在控件无效时显示在控件中。10) DownPicture 属性:设置或返回一个对图片的引用,该图片在控件被单击处于压下状态时显示。11) DragIcon属性:设置或返回图标,它将在拖放操作中做为指针显示。12) DragMode属性:设置返回一个值,确定在拖放操作中所用方式。13) Font属性:设置或返回字体的属性。14) Name属性:设置或返回控件的标识名。15) Value属性:设置或返回控件的状态。u 复选按钮类的控件的基本事件:1) Click事件:鼠标单击控件时发生。2) Dr
25、agDrop事件:在一个完整的拖放动作完成或使用Drag方法,并将其Action参数设置为2时发生。3) DragOver事件:在拖放操作正在进行时发生。4) GotFocus事件:在对象获的焦点时发生。,5) OLECompleteDrag事件:当源部件被放到目标时发生,并通知源部件拖放操作被执行或取消。6) OLEDragDrag事件:当源部件决定放操作能发生,却源部件被放到目标部件时,此事件发生。u 框架类的控件:1) List属性:列表框控件的表项是使用数组的方式保存,数组的每一个元素存储列表控件的一个表项1) Listcount属性:控件列表部分项目的个数。2) Mutselect属
26、性:可以设置列表框为单选或允许多选属性.3) Selectd属性:标示一个数组,数组各元素为:4) Selected(0),selected(1)u 滚动条类的控件:1) Value属性:滚动条上滑块所在位置由value值所决定。2) Max和min属性:对value值的最大,最小进行限制。3) Largechange属性:用户点击滚动条与键头之间的区域时,value的改变量。4) OnClick事件:用来添加按钮的单击事件所执行的程序代码。u 定时器类类的控件:1) Interval属性:表示定时的时间间隔,以毫秒为单位。2) Enable属性:为true时(缺省值),激活定时器开始计时;为
27、false时处于休眠状态.数据库连接方式选择Visual basic6.0连接数据库的主要方式以下几种方式:一是:用data控件进行数据库链接 ,二是利用adodc(ADO Data Control)进行数据库链接 。三是: 利用DataEnvironment进行数据库链接.四是利用ADO(ActiveX Data Objects)进行编程:现在我们来大致对这几种技术应用介绍:一、 用data控件进行数据库链接.第一步:给窗体添加一个Data控件。第二步:用Access建立一个名为Pad的数据库,在库中建立一个表Myset,给表添加四个字段:backcolor(数据),forecolor(文本
28、),fontname(文本),fontsize(文本)。注意:请将库文件存入程序所在目录。 如果你的机器没安装有Access,可通过VB建库。二、 利用adodc(ADO Data Control)进行数据库链接:使用adodata控件访问数据库可以完全不用编写代码,只需要通过简单的设置和操作其属性就可以实现与数据库的连接,通过绑定数据感知控件,就能提供一个访问数据库的界面,用来实现对数据库的浏览,贴加,删除,修改等操作.三、 利用DAO对数据库进行操纵:在visual basic 中提供了两种与jet数据引擎接口的方法:data控件与数据访问对象(DAO)DAO是database objec
29、t的英文缩写,要访问数据库一方面数据库要提供访问接口,另一方面要在编程环境中有对数据库的支持.DAO模型是设计关系数据库系统结构的对象类的集合.他们提供了管理关系型数据库系统所需要的全部操作属性和方法,这其中包括建立数据库,定义表,字段和建立表间关系,定位和查询数据库等.关系数据库介绍:关系数据库是目前各类数据库中最重要、最流行的数据库,他应用数学方法来处理数据库数据,是目前使用最广泛的数据库系统。20世纪70年代以后开发的数据库管理系统产品几乎都是基于关系的。在数据库发展的历史上,最重要的成就就是关系模型。 关系数据库系统与非关系数据库系统的区别是:关系系统只有“表“这一种数据结构;而非关系
30、数据库系统还有其他数据结构,对这些数据结构有其他的操作。结构化查询语言SQL(Structured Query Language)是一种介于关系代数与关系演算之间的语言,其功能包括查询、操纵、定义和控制四个方面,是一个通用的、功能极强的关系数据库语言。目前已成为关系数据库的标准语言MicrosoftAccess介绍:使用MicrosoftAccess,可以在单一的数据库文件中管理所有的信息。在这个文件中,用户可以将自己的数据分别保存在各自独立的存储空间中,这些空间称作表;可以使用联机窗体来查看、添加及更新表中的数据;使用查询来查找并检索所要的数据;也可以使用报表以特定的版面布置来分析及打印数据
31、。 如果要保存数据,请为每一种类型的信息创建一个表。如果要从查询、窗体或报表中的多个表中将数据合并在一起,就要定义各个表之间的关系。 如果要搜索并检索符合指定条件的数据,包括来自多个表中的数据,就要创建查询。查询的同时也可以更新或删除多条记录,并对数据执行内嵌或自定义的计算。 如果要简单地直接在某个表中查看、输入及更改数据,请创建一个窗体。在打开一个窗体时,MicrosoftAccess将从一个或多个表中检索数据,并使用用户在“窗体向导”选择的版面布局或所创建的版面布局,将窗体显示在屏幕上。 如果要分析数据或将数据以特定的方式打印出来,请创建一个报表。例如,可以打印一份将数据分组并计算数据总和
32、的报表,也可以打印另一份带有各种数据格式的打印邮件标签的报表。第二章 系统的分析第一章 系统的分析21 系统开发的目标和思想本系统开发目标是服务于高速公路收费管理人员,方便工作人员,对过往车辆收费,发放收费票据记录,对信息的分类管理等.同时力求做到界面人性化,功能齐全,数据存储安全.22 系统的可行性分析技术上:本系统采用visual basic 6.0与微软的access作为数据库,技术上开发难度一般.经济上:本系统服务于高速公路收费管理人员,提高了工作人员办事效率,节省了开支.所以具有经济上的可行性.社会上:本系统同时也方便了广大司机朋友,以及乘客.所以具有社会可行性.第二章 系统的设计3
33、1 系统的功能结构设计程序登陆主界面数据操作查询用户管理修改密码视图窗口帮助32 系统的数据库设计1:数据表:2:sfyinfo表设计:3:用户信息表:32 界面设计与代码设计1:登陆界面设计:代码分析:Dim flagpassword As StringDim flagadmin As StringOption ExplicitPrivate Sub cmdcancel_Click()Me.HideEnd SubPrivate Sub cmdok_Click()Dim conlogin As New ADODB.ConnectionDim rstlogin As New ADODB.Reco
34、rdset If Len(Trim(txtgonghao.Text) = 0 ThenMsgBox 工号为空,请重新输入!, vbOKOnlyExit SubEnd IfIf Len(Trim(txtPassword.Text) = 0 ThenMsgBox 用户密码为空,请重新输入!, vbOKOnlyExit SubEnd If With conloginIf .State = adStateOpen Then .CloseEnd If .Provider = microsoft.jet.oledb.4.0 .ConnectionString = App.Path & jinbin.mdb
35、 .OpenEnd WithWith rstloginIf .State = adStateOpen Then .CloseEnd If .LockType = adLockReadOnly .CursorLocation = adUseClient .CursorType = adOpenDynamic .ActiveConnection = conlogin .Source = select * from userinfo .Open If Trim(txtPassword.Text) = flagpassword And Len(Trim(txtPassword.Text) = Len(
36、flagpassword) ThenIf flagadmin = 高级用户 Thenwt.flagnumber = 79802223Unload Memainfrm.ShowElseIf flagadmin = 一般用户 Thenwt.flagnumber = 32220897Unload Memainfrm.ShowElseMsgBox 非法人员及权限,请找管理员, vbOKOnlyExit SubEnd IfElseMsgBox 密码错误,请重新输入Exit SubEnd IfEnd WithEnd SubPrivate Sub txtgonghao_LostFocus()Dim conl
37、ogin As New ADODB.ConnectionDim rstlogin As New ADODB.RecordsetIf Len(Trim(txtgonghao.Text) 0 ThenWith conloginIf .State = adStateOpen Then .CloseEnd If .Provider = microsoft.jet.oledb.4.0 .ConnectionString = App.Path & jinbin.mdb .OpenEnd WithWith rstloginIf .State = adStateOpen Then .CloseEnd If .
38、LockType = adLockReadOnly .CursorLocation = adUseClient .CursorType = adOpenDynamic .ActiveConnection = conlogin .Source = select userid,username,userpassword,userjibie from userinfo where userid= & Trim(txtgonghao.Text) & .OpenIf .RecordCount 0 ThenDo Until .EOFtxtusername.Text = Trim(.Fields!UserN
39、ame.Value)flagpassword = Trim(.Fields!userpassword.Value)flagadmin = Trim(.Fields!userjibie.Value).MoveNextLoopElseMsgBox 输入的工号非法,请重新输入, vbOKOnlytxtgonghao.Text = txtgonghao.SetFocusExit SubEnd IfEnd WithEnd IfEnd Sub2:添加用户界面设计:代码设计:Private Sub cmdadd_Click()Dim conuser As New ADODB.ConnectionDim cm
40、duser As New ADODB.CommandDim rstuser As New ADODB.RecordsetDim strcnn As String输入数据进行验证If Len(Trim(txtuser.Text) = 0 ThenMsgBox 用户名没有输入,请输入!, vbOKOnlyExit SubElsetxtuser.Text = CStr(Trim(txtuser.Text)End IfIf Len(Trim(txtgonghao.Text) = 0 ThenMsgBox 工号没有输入,请输入!, vbOKOnlyExit SubElsetxtgonghao.Text
41、= CStr(Trim(txtgonghao.Text)End If If Len(Trim(txtpassword.Text) = 0 ThenMsgBox 密码没有输入,请输入!, vbOKOnlyExit SubElsetxtpassword.Text = CStr(Trim(txtpassword.Text)End IfIf Len(Trim(txtpassword2.Text) = 0 ThenMsgBox 请输入确认密码!, vbOKOnlyExit SubElsetxtpassword2.Text = CStr(Trim(txtpassword2.Text)End IfIf tx
42、tpassword.Text txtpassword2.Text ThenMsgBox 确认密码和第一次输入的密码不同,请重新输入!, vbOKOnlyExit SubEnd Ifstrcnn = insert into userinfo(username,userid,userpassword,userjibie)values( & txtuser & , & txtgonghao & , & txtpassword & , & Comboqx.Text & ) With conuserIf .State = adStateOpen Then .CloseEnd If .Provider =
43、 microsoft.jet.oledb.4.0 .ConnectionString = App.Path & jinbin.mdb .ConnectionTimeout = 10 .OpenEnd WithWith cmduser .ActiveConnection = conuser .CommandType = adCmdText .CommandText = strcnn .ExecuteEnd WithMsgBox 添加用户信息到数据库的操作成功, vbOKOnly, 确认框txtuser.Text = txtgonghao.Text = txtpassword.Text = txt
44、password2.Text = strcnn = select userid as 用户工号, username as 用户姓名,userjibie as 用户级别 from userinfoWith rstuser .CursorLocation = adUseClient .CursorType = adOpenStatic .LockType = adLockOptimistic .ActiveConnection = conuser .Open strcnn, Options:=adCmdText Set Adouser.Recordset = rstuser dtguserinfo.ReBindEnd WithEnd SubPrivate Sub cmdcancel_Click()txtuser.Text = txtgongh