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了。