• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

数据库综合开发实践

发布: 2008-10-14 11:43 | 作者: 马磊、张万里 | 来源: programfan.com  | 查看: 52次 | 进入软件测试论坛讨论

领测软件测试网

四、ODBC的问题

  在C++Builder中有的地方要用到SQL查询,因此,有一段程序使用的是ADOQuery控件,本来这种用法在其他机器上用过,没有问题,可是在这里却不行。具体情况如下:放置一个ADOQuery,ConnectionString属性、TableName属性和前面的ADOTable属性设置一样,Active属性保持false,再添加一个DataSource控件和几个DBText控件,设置同前。然后在FormCreate(表单构造函数)中添加如下代码:

  ADOQuery1->Active=false;

  ADOQuery1->SQL->Clear();

  ADOQuery1->SQL->Add("select * from Names order by ID");

  ADOQuery1->Active=true;

  while (!ADOQuery1->Eof)

  {

    ComboBox1->Items->Add(ADOQuery1->FieldByName("Name")->AsString);

    ADOQuery1->Next();

  }

  //后一段

  ADOQuery1->Active=false;

  ADOQuery1->SQL->Clear();

  ADOQuery1->SQL->Add("select * from Dutys order by ID");

  ADOQuery1->Active=true;

  while (!ADOQuery1->Eof)

  {

    ComboBox2->Items->Add(ADOQuery1->FieldByName("Duty")->AsString);

    ADOQuery1->Next();

  }

  就这么一段代码,在该机器上怎么都不能运行,系统总是提示“BOF或EOF中有一个为真”的错误,将注释后面的一段删掉,系统可以运行,但退出程序时出现非法错误,说明是带故障运行。反复查看找不出程序的明显错误,把程序拿到其他机器上可以通过,两个机器的最主要差别就是ODBC的版本不同。

  于是想将ODBC降为2.5英文版,找到MDAC2.5版安装了几次都不行,只好手工删除了,在WINDOWS目录中搜索出所有前缀为ODBC的文件,然后删除program files\common files中的system目录,再重新安装MDAC(Microsoft Data Access Component 2.5英文版),再运行该程序,一切正常。

  五、结论

  不知道是MDAC2.6版本的问题,还是因为它是中文版的问题,总之,造成系统的兼容性不是很好,建议大家在编程时也应该尽量使用已经熟悉的环境,而不要总是去尝试太新的东东。

  当然,如果是我这一段代码有问题,还希望有高手能出来指导。

  以上是我们在一次数据库系统的移植开发过程中出现问题和解决方法的真实记录,虽然问题都很小,但是让我们在开发过程中走了不少弯路,所以把它记录下来,供大家参考,希望对朋友们的开发有所帮助。其中的问题也希望有朋友能够指出更好的解决办法。

文章来源于领测软件测试网 https://www.ltesting.net/

33/3<123

关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网