TDataSet的Eof属性

发布时间:2020-06-14 00:43:08 作者:alexanda2000
来源:网络 阅读:182

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

推荐阅读:
  1. sybase bcp Unexpected EOF enco
  2. 一个<<-EOF引发的血案

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

编程语言 其他 dat

上一篇:大数据之---hadoop伪分布式部署(HDFS)全网终极篇

下一篇:基于NXP i.MX 8M Mini芯片的MYC-C8MMX

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》