TDataSet的Eof属性-创新互联

TDataSet类的Eof属性应该无人不知,只要写过数据库的,基本上都写过以下的逻辑:

成都创新互联专注于双城企业网站建设,响应式网站,电子商务商城网站建设。双城网站建设公司,为双城等地区提供建站服务。全流程专业公司,专业设计,全程项目跟踪,成都创新互联专业和态度为您提供的服务

cdsDatabases.First;

while not cdsDatabases.Eof do

begin

(业务逻辑)

cdsDatabases.Next;

end;

这样的逻辑理所当然,可能大家也不一定会深究。但是如果问,当游标指向最后一条记录时,Eof返回的是True还是False?多数人可能都会愣一下。

事实上,答案是要看当时的情况。

在官方文档中,列出了Eof为True的几种情形:

Opens an empty dataset.

Calls a dataset's Last method. (Unless it is a unidirectional dataset)

Call a dataset's Next method, and the method fails because the current record is already the last row in the dataset.

Calls SetRange on an empty range or dataset.

即:

打开空数据集时

调用Last方法去到最后一条记录时

调用next方法,因当前已是数据集的最后一条记录,所以next失败时

在空数据集中调用SetRange方法时

除了以上的4种情况,其余情形Eof都为false.

上面的代码之所以正确,是因为使用的是next,第一次指向最后一条记录时,方法是成功的,所以当时的Eof是false,在最后一条记录调用next时,方法失败,游标指向的仍然是最后一条记录,但这时候Eof已经是true了。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前题目:TDataSet的Eof属性-创新互联
本文URL:http://ybzwz.com/article/jiooh.html