网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Visual Basic
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.为你的VB程序程序加密(VB新手).
.提高VisualBasic访问数据库的效率.
.DirectX7.0使用心得(2).
.VisualBasic控件的使用.
.用API函数遍历指定驱动器、目录的.
.VB中播放三维动画编程一例.
.VB编程经验点滴.
.VBCOM基础讲座之创建第一个COM对.
.复制字符串中的字符.
.VB里实现帮助文件速成.
.怎样在vb.net中将图片存入SQL Se.
.用VB进行移位操作.
.制造出透明的窗体(Form).
.即时即战游戏的写法.
.建立、改变及重构Access数据库.
.VisualBasic对象使用二.
.一组VB实用小程序.
.在VB中直接用ODBCAPI访问数据库.
.用MDB文件做admin888库.
.显示多媒体信息.

在VB中引用.dbf及索引文件

发表日期:2006-2-27


如何用FOX以外的编程语言来取得.dbf数据库的记录值和引用.idx和.cdx索引一直都是程序员讨论的话题之一。现有一任务是在一个触摸屏系统中加入一个用户查询水费界面。每个用户可随时查询到自己的水费记录。我使用VB5.0,希望打开NetWare系统下营业收费系统的七个.dbf数据表并进行查询。每个数据表有将近10万条记录。通过10M集线器交换数据,查询的字段都不是唯一的。显然这样大的数据量,又是通过10M网络传递,如果VB使用SQL方式查询,则最少要2分钟时间才能得到答复。让一个用户在机器旁边等2分钟是不现实的。于是想利用FoxPro自身的.idx或.cdx索引文件来查找。
  编程可用两种方式实现。一种是直接在VB中调用,另一种使用VB中的shell函数调用FoxPro的exe程序。
  方法一、直接在VB中调用.dbf文件
  一、.在FoxPro数据库的所在目录下建立一个与FoxPro数据库文件名相同的.inf文本文件
  步骤:1.创建文本文件*.inf,与数据表同名。
  2.在文本文件的第一行,输入[FoxPro2.5];如果指定的是FoxPro2.0索引,则输入[FoxPro2.0],其余以此类推。
  3.依次输入各指定索引文件名形式IDXn=*.idx或CDXn=*.cdx。其中n为数字,依次表示第1个IDX索引文件,第2个IDX索引文件。或第1个CDX索引文件,第2个……以此类推。
  注意:如果不能将.inf文件与数据库存储在同一目录下,或为了维护方便而希望将所有文件存储在一个共享点。可采用创建Windows注册表项的方法,指向存储.inf的文件路径。(详见VB5的联机手册)
  二、编写程序
  用OPENDATABASE方法直接打开外部FoxPro表。
  主要语句如下:
  dimdbasdatabase
  dimtbasrecordset
  ′打开外部数据库
  setdb=opendatabase(“c:\fox\”,false,false,”foxpro2.5;”)′注意FoxPro与2.5之间必须有空格
  settb=db.openrecordset(“abc”)
  ′调用索引
  tb.index=“abc1#idx”′注意索引名为“索引文件名#后缀名”
  tb.seek“=”,“111-111”′搜索唯一值为“111-111”的记录
  方法二、用shell()函数调用VF的idx文件
  用VB接受用户命令,然后调用VF的.prg编译的.exe文件,按用户要求在数据库中查询,将查询结果放置在一个.TXT文件中。VB从.TXT文件取数显示,再次将查询结果传递给VF的.prg编译的.exe文件,查询取数结果。具体编程从略,这里要着重讨论shell()函数的特性:shell函数是以异步方式来执行其它程序的。也就是说,用shell启动的程序可能还没有完成执行过程,就已经执行到shell函数之后的语句。这种执行方式打乱了程序固有的顺序执行方式,如果不加注意,程序的运行将产生混乱。
  如果语句如下
  ……
  shell(c:\file1.exe)′调用file.exe文件,并把结果放置在X1.txt中
  openc:\x1.txtforoutputas#1′打开X1.TXT文件,取查询结果。
  ……
  按一般执行方式,上述语句应能正确执行。然而实际运行时,即使语句全部正确,也会弹出错误信息框:x1.txt文件不存在。原因就在于VB在执行shell()语句时,file1.exe文件还未执行完,就继续下一行语句:打开file1文件创建的x1.txt;所以出现错误。
  经过多次实验,我最后采用了VB工具条中的timer控件来完成时间等待,程序编程通过。
  ……
  shell(c:\file1.exe)
  ‘运行计时器
  timer1.enabled=true
  ……
  subtimer1_timer()
  ifdir(“c:\x1.txt”)<>””then
  openc:\x1.txtforoutputas#1
  ……
  timer1.enabled=false
  endsub
实际运行速度很快,2~3秒内完成查询操作。->

上一篇:VB中使用数据窗体设计器插件 人气:3733
下一篇:在VB中直接用ODBCAPI访问数据库 人气:2895
浏览全部Visual Basic的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐