中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Delphi > 综合文章
An Unknown error has occurred -- EOleException 解决方法
作者:未知 时间:2005-02-03 12:12 出处:Blog 责编:chinaitpower
              摘要:暂无
今日开发遇到一个错误:

Delphi 7.1。
使用
ADO连接SQL Server,Book_ADOQuery有一个Lookup字段,每当Insert/Append的时候IDE就会弹出一个错误:

An Unknown error has occurred -- EOleException

跟踪发现错误来源于VCL LocateRecord方法的FLookupCursor.Find

function TCustomADODataSet.LocateRecord(const KeyFields: string;
  const KeyValues: OleVariant; Options: TLocateOptions;
  SyncCursor: Boolean): Boolean;

 if FieldCount = 1 then
          FLookupCursor.Find(GetFilterStr(FieldByName(KeyFields), KeyValues, Partial), 0,
             adSearchForward, EmptyParam)
   
而且如果连接Access数据库也没有问题。

通过Google发现,该Bug在Delphi 5中就有了:
http://info.borland.com/devsupport/delphi/fixes/delphi5/database.html

Area: database\ado

Reference Number: 72996
Status: Open
Date Reported: 10/14/99
Severity: Commonly Encountered
Type: Minor Functionality Failure

Problem:

When using Lookup fields, inserting a record will 
generate "An unknown error has occured" 
exception in some cases.

Workaround:

Requires VCL code changes.
Install Update Pack.








最后通过研究另外一个类似问题,发现:
只要把所有Lookup字段的lookupCache设为True(缺省为False)就可以避免该错误。


特记于此。


关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有