為什麼RecordCount會是-1? |
尚未結案
|
piggy213
一般會員 發表:16 回覆:6 積分:4 註冊:2002-12-27 發送簡訊給我 |
|
hagar
版主 發表:143 回覆:4056 積分:4445 註冊:2002-04-14 發送簡訊給我 |
參考一下 Help 的說明: Note: Use RecordCount with care, because record counting
can be a costly operation, especially for SQL queries that
return large result sets. Generally, an application should
only use RecordCount with Paradox and dBASE tables. ---
歡迎光臨 KTop 研究院--<-<-<@
|
Mickey
版主 發表:77 回覆:1882 積分:1390 註冊:2002-12-11 發送簡訊給我 |
節錄一段 TDataSet.Recordcount Property Delphi 7 VCL 線上說明 : As implemented in TDataSet, RecordCount is always -1.
Ordinarily an application does not access RecordCount at the
TDataSet level. Instead a redeclared and implemented RecordCount
property in a descendant class is accessed.
RecordCount provides a fallback property for derived dataset
classes that do not reimplement the property access method. 參考看看 :
http://delphi.ktop.com.tw/topic.php?TOPIC_ID=29579
|
heartsong
一般會員 發表:11 回覆:13 積分:4 註冊:2003-07-17 發送簡訊給我 |
|
miller680523
一般會員 發表:47 回覆:49 積分:19 註冊:2002-10-28 發送簡訊給我 |
|
heartsong
一般會員 發表:11 回覆:13 積分:4 註冊:2003-07-17 發送簡訊給我 |
这个问题我也不是很清楚,我查了一下DELPHI自带的db这个模块关于RecordCount部分的代码,里面是两个线程,都是这样定义RecordCount的 property RecordCount: Integer read GetRecordCount;
注意,上面两个GetRecordCount在两个线程中这样定义:
function TDataLink.GetRecordCount: Integer;
begin
if DataSource.State = dsSetKey then Result := 1 else
begin
Result := DataSource.DataSet.FRecordCount;
if Result > FBufferCount then Result := FBufferCount;
end;
end;
另外一个:
function TDataSet.GetRecordCount: Longint;
begin
Result := -1;
end;
我认为,第一个GetRecordCount值是正确的值,即数据集是实际的数据行数,只有RecordCount得到了第二个GetRecordCount值(即是-1)时,所以得到RecordCount为-1,至于怎么会得到第二个GetRecordCount值,我发现是在你的DBGrid的显示行数<数据集的行数得到,比如,我要查询的数据集中实际上是9行,而DBGrid的显示行数=8行,这时,用RecordCount时会得到第二个GetRecordCount值的,即为-1。
所以我认为,当用了Last以后,即把DBGrid所显示的行数不会使之小于实际的数据集中的数据行数,RecordCount也就能得到第一个GetRecordCount,即正确的值的。至于是否是这样,我想你可以通过断点进行一一执行查看(呵呵,这个比较费时间,我就是这样做,结果没有做完就退出来了) 心灵琴音界
灵透结界石
------
心灵琴音界 灵透结界石 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |