电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 办公软件-> Powerpoint教程
在vb中引用.dbf及索引文件_visualbasic教程
作者:网友供稿 点击:0
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
如何用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秒内完成查询操作。->


文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·vb的“问”与“答”_visualbasic教程
·“牛刀小试”powerpoint 2003的刻录cd功能_powerpoint教程
·巧用powerpoint制作比赛计时器_powerpoint教程
·autocad的基本命令_autocad教程
·布局的创建与管理_autocad教程
·给powerpoint演示文挡来个大瘦身_powerpoint教程
·微软拟推新搜索引擎 称google蜜月期将结束_搜索引擎
·photoshop将普通风景照变为美丽夜景_photoshop教程
·用vb6.0设计简易赛车游戏_visualbasic教程
·编写快速高效的vb程序_visualbasic教程

最新文章
·photoshop照片合成实例:添加烟花_photoshop教程
·用photoshop通道打造“非主流”淡彩照片_photoshop教程
·用powerpoint生动地演示几何应用题_powerpoint教程
·photoshop绘制错乱拼帖立体特效字_photoshop教程
·在windows xp中优化和维护vista系统_windows xp
·拯救windows xp操作系统崩溃的救命稻草_windows xp
·powerpoint演示文档中声音的控制技巧_powerpoint教程
·photoshop打造奇幻的光线效果图_photoshop教程
·php mysql integration_php技巧
·共享与重复使用powerpoint2007幻灯片内容_powerpoint教程


 
 


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号