VB数据库数据的选项录入及选项增减与编辑

2016-02-19 12:28 18 1 收藏

岁数大了,QQ也不闪了,微信也不响了,电话也不来了,但是图老师依旧坚持为大家推荐最精彩的内容,下面为大家精心准备的VB数据库数据的选项录入及选项增减与编辑,希望大家看完后能赶快学习起来。

【 tulaoshi.com - 编程语言 】

在VisualBasic数据库编程中,应用数据绑定组合框和数据绑定网格等控件实现了数据的选项录入、选项增减与选项编辑,提高了数据录入效率和准确性。
  
  高效准确地录入数据已成为mis系统急待解决的问题,也是衡量mis系统成功的重要标志。本文在VisualBasic数据库编程中应用数据绑定组合框和数据绑定网格等控件实现了数据的选项录入、选项增减与数据编辑,提高了数据录入效率、准确性及灵活性。(
  
  考察mis系统涉及的数据性质、值域范围和变化程度,可以发现在mis系统数据录入中往往出现下列情况
  
  (1)连续录入的几条记录中,同名字段的内容完全相同或基本相同,如省份、职称等;用户逐字录入速度慢易出错,因此应充分利用数据库中的已有数据,设置一个复制键将上条记录中的同名字段的内容复制到当前记录的同名字段中;
  
  (2)有些字段的值域固定,因此程序应提供一个合法的选项框供用户选择来提高速度;
  
  有些字段的值域较小且相对固定,但有一定的变化,如“省市”字段增设一个省或市,撤县设市等等,程序除提供一个合法的基本的选项框供用户选择外,且应允许用户对这个基本的选项框进行增减或编辑。
  通过上述方法使录入速度进一步得到提高,使用户的功效达到事半功倍的效果。

1数据库基本录入界面的设计
  
  首先用vb中的数据管理器创建一个access数据库“c:my.mdb”,在表“worker”中加入一个字段“name”,然后在vb的缺省表单中拖入一个数据控件、一个文本框、一个表签、一个命令按钮组,合理设计界面布局,并设置各个控件的属性,如表1。
  
  加入下列代码即可得到一个数据库基本输入窗口:
  
  privatesubcommand1-click(indexasinteger)
  
  selectcaseindex
  
  case0'addnew
  
  data1.recordset.addnew
  
  text1.setfocus
  
  case1'edit
  
  data1.recordset.edit
  
  text1.setfocus
  
  case2'giveup
  
  data1.recordset.cance1update
  
  data1.refresh
  
  case3'save
  
  data1.recordset.update
  
  data1.refresh
  
  case4'delete
  
  data1.recordset.delete
  
  data1.refresh
  
  case5'end
  
  end
  
  endselect
  
  endsub
  
  表一

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)-align="middle"width="33">控件名->-align="middle"width="33">属性名->-align="middle"width="34">属性值->-width="33">Data->-width="33">Data1->-width="34">DatabaseName=c:my.mdb
  RecordSource="worker"->-width="33">Text->-width="33">Text1->-width="34">Text=""
  RecordSource="Data1"
  DataField="Name"->-width="33">Label->-width="33">Label1->-width="34">Caption="姓名"->-width="33">CommandButton->-width="33">Command1->-width="34">Index=0
  Caption="新增"->-width="33">CommandButton->-width="33">Command1->-width="34">Index=1
  Caption="编辑"->-width="33">CommandButton->-width="33">Command1->-width="34">Index=2
  Caption="放弃"->-width="33">CommandButton->-width="33">Command1->-width="34">Index=3
  Caption="保存"->-width="33">CommandButton->-width="33">Command1->-width="34">Index=4
  Caption="删除"->-width="33">CommandButton->-width="33">Command1->-width="34">Index=5
  Caption="退出"->

  在连续录入的几条记录中,同名字段的内容完全相同或基本相同,此时若能充分利用数据库中的已有数据,设置一个复制键将上条记录中的同名字段的内容复制到当前记录的同名字段中,将能大提高数据录入速度。为了便于用户操作,将这一功能赋予ctrl键,用户在录入新记录或编辑原有记录时,只要按下ctrl键,则上条记录中的同名字段的内容就复制到当前记录的同名字段中。程序如下:
  
  OptionExplicit
  
  DimlastAsString
  
  PrivateSubform_Activate()
  
  DimmarkAsVariant
  
  mark=Data1.Recordset.Bookmark
  
  Data1.Recordset.MoveLast
  
  last=Data1.Recordset("Name")
  
  Data1.Recordset.Bookmark=mark
  
  EndSub
  
  privatesubtext1-keydown
  
  (keycodeasinteger,shiftasinteger)
  
  ifshift=2then'按下ctrl-key复制上条记录中的同名字段的内容
  
  ifdata1.recordset.editmode=dbeditinprogress
  
  ordata1.recordset.editmode=dbeditaddthen
  
  text1.text=last
  
  endif
  
  endif
  
  endsub
  
  privatesubCommand1_Click(indexasinteger)
  
  selectcaseindex
  
  case0'addnew
  
  data1.recordset.addnew
  
  text1.setfocus
  
  case1'edit
  
  data1.recordset.edit
  
  text1.setfocus
  
  case2'giveup
  
  data1.recordset.cance1update
  
  data1.refresh
  
  case3'save
  
  data1.recordset.update
  
  data1.recordset.movelast
  
  last=data1.recordset("name")'savethetexttolast
  
  data1.refresh
  
  case4'delete
  
  data1.recordset.delete
  
  data1.refresh
  
  case5'end
  
  end
  
  endselect
  
  endsub
  
  3数据的选项录入、选项增减及选项编辑
  
  有些字段的值域较小且相对固定,但会有一定的变化,如“省市”字段会产生变化,如增设一个省或市,撤县设市等等,程序除提供一个合法的基本的选项框供用户选择外,还应允许用户对这个基本的选项框进行增减或编辑。下面的程序实现了此功能,用户双击表单则可对选项框进行增减和编辑,完成后再双击表单关闭编辑功能。
  
  先建立一个数据库“c:myrand.mdb”,其表“rank”中加入一个字段“name”;再从工具箱中拖入一个数据控件data2,一个数据绑定组合框dbcombol和数据绑定网格控件dbgrid1。属性设置为:(1)data2控件的:databasename属性设为“c:myrand.mdb”,recordsource为“rank”;(2)dbcombo控件的:name设为dbcombo1,rowsource设为data2,listfiele设为“name”,datasource设为data1。datafield设为“name”;(3)dbgrid控件的:name设为dbgrid1,将allowaddnew、allowdelete、allowupdate均设为true,datasource设为data2。
  
  程序代码如下:
  
  optionexplicit
  
  dimlastasstring
  
  dimddasboolean
  
  privatesubform-activate()
  
  dimmarkasvariant
  
  mark=data1.recordset.bookmark
  
  data1.recordset.movelast
  
  last=data1.recordset("name")
  
  data1.recordset.bookmark=mark
  
  text1.visible=true
  
  dbcombol.visible=false
  
  dbgrid1.visible=false
  
  endsub
  
  privatesubform-dblclick()'双击表单打开或关闭选项增减和选项编辑功能
  
  staticddasboolean
  
  dd=notdd'第一次双击打开编辑功能第二次双击关闭编辑功能
  
  ifddthen
  
  dbgrid1.visible=true
  
  else
  
  dbgrid1.visible=false
  
  exitsub
  
  endif
  
  endsub
  
  privatesubdbgrid1-dblclick()'选择当前项后,再双击删除当前记录选项
  
  data2.recordset.delete
  
  dbcombol.refresh
  
  dbgrid1.refresh
  
  endsub
  
  privatesubdbgrid1-lostfocus()
  
  dbcombol.refresh'刷新dbcombol
  
  endsub
  
  privatesubcommand1-click(indexasinteger)
  
  dimiasinteger
  
  selectcaseindex
  
  case0'addnew
  
  data1.recordset.addnew
  
  dbcombol.setfocus
  
  dbcombol.visible=true
  
  text1.visible=false
  
  case1'edit
  
  data1.recordset.edit
  
  text1.setfocus
  
  dbcombol.visible=false
  
  text1.visible=true
  
  case2'giveup
  
  data1.recordset.cance1update
  
  data1.refresh
  
  dbcombol.visible=false
  
  text1.visible=true
  
  case3'save
  
  data1.recordset.update
  
  data1.recordset.movelast
  
  last=data1.recordset("name")
  
  data1.refresh
  
  dbcombol.visible=false
  
  text1.visible=true
  
  case4'delete
  
  data1.recordset.delete
  
  data1.refresh
  
  case5'end
  
  end
  
  endselect
  
  endsub
  
  privatesubdbcombol-keydown
  
  (keycodeasinteger,shiftasinteger)
  
  ifshift=2then'按下ctrl-key复制上条记录中的同名字段的内容
  
  ifdata1.recordset.editmode=dbeditinprogressor
  
  data1.recordset.editmode=dbeditadd
  
  then
  
  dbcombol.text=last
  
  endif
  
  endif
  
  endsubprivatesubtext1-keydown(keycodeasinteger,shiftasinteger)
  
  ifshift=2then'按下ctrl-key复制上条记录中的同名字段的内容
  
  ifdata1.recordset.editmode=dbeditinprogressor
  
  data1.recordset.editmode=dbeditadd
  
  then
  
  text1.text=last
  
  endif
  
  endif
  
  endsub
  
  通过上述方法使录入速度进一步得到提高,使用户的功效达到事半功倍的效果。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)->

来源:http://www.tulaoshi.com/n/20160219/1600993.html

延伸阅读
在VB中,用microsoftjet数据库引擎和数据访问对象DAO(dataaccessobject)可以创建功能强大的客户/服务器应用程序。对远程数据库的访问是开发这类应用程序的关键环节,本文将介绍在VB中用DAO通过miscrosoftjet数据库引擎访问远程数据库的方法。 用DAO访问远程数据库大体上可以通过三步来实现,即数据连接、数据处理和断开连接。下面主...
VB全称VisualBasic,是微软公司推出的基于Basic语言的可视化编程环境,以其简单易学功能强大而倍受广大电脑爱好者的青睐。 VB的数据库编程方面按其难易程度可分为三类(由易到难); ●使用数据库控制项和绑定控制项 ●使用数据库对象变量进行编程 ●直接调用ODBC2.0API 在使用VB进行数据库编程时,通常,会首先选择三种基本方法之...
用Visual Basic访问数据库有许多可供选择的方案,但是选择那种方案更能使开发队伍和应用软件在今天处于有利位置并且适应将来的发展方向呢?这些解决方案各有什么特点?本文将说明这些问题,帮助使用VB5的用户和准备使用VB5的用户选择和决定哪种数据库访问方案对现在很有意义而且适应将来的应用程序。 当今,RDO2.0是Visual Basic访问关...
标签: SQLServer
  在第一部分,我们讨论了如何优化 ASP 代码。在这一部分,我们把重点放在数据访问上。 一般情况下,数据访问时间要比 ASP 代码解释,编译时间长,不要让数据检索成为影响 ASP 性能的瓶颈。 首先,讲一些老生常谈的话。比如:需要声明变量,要用 Response.Write SQL_string 来进行调试,要用 On Error Resume Next 来捕获错误。不要在 ...
摘要VisualBasic有着强大的数据库存取能力,不仅能够直接支持MsAccess数据库,而且通过其内部安装的ISAM驱动程序使它能间接支持FoxPro、dBASE等外来数据库。本文不仅从VB数据库体系结构的角度探讨了VB对这些外来数据库的支持,还结合了一些实例具体阐述了使用数据库存取对象变量的方法实现这些外来数据库的新建、库结构修改、显示及其运行环境设...

经验教程

505

收藏

99
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部