From 135f5f0e33c9cba9a1b52350108a217d63151c32 Mon Sep 17 00:00:00 2001 From: Jake Smith Date: Wed, 29 Nov 2023 11:00:53 +0000 Subject: [PATCH] HPCC-30938 checkCount/getCount double counting seeks checkCount/getCount does not need to count/note seeks, because the _lookup it calls that is passed the same 'stats' container already does so. Signed-off-by: Jake Smith --- system/jhtree/jhtree.cpp | 6 ------ 1 file changed, 6 deletions(-) diff --git a/system/jhtree/jhtree.cpp b/system/jhtree/jhtree.cpp index 22daf58860a..86c358c1958 100644 --- a/system/jhtree/jhtree.cpp +++ b/system/jhtree/jhtree.cpp @@ -2027,7 +2027,6 @@ unsigned __int64 CKeyCursor::getCount(KeyStatsCollector &stats) { reset(); unsigned __int64 result = 0; - unsigned lseeks = 0; unsigned lastRealSeg = filter->lastRealSeg(); bool unfiltered = filter->isUnfiltered(); for (;;) @@ -2037,7 +2036,6 @@ unsigned __int64 CKeyCursor::getCount(KeyStatsCollector &stats) unsigned __int64 locount = getSequence(); endRange(lastRealSeg); _ltEqual(stats); - lseeks++; result += getSequence()-locount+1; if (!incrementKey(lastRealSeg)) break; @@ -2045,7 +2043,6 @@ unsigned __int64 CKeyCursor::getCount(KeyStatsCollector &stats) else break; } - stats.noteSeeks(lseeks, 0, 0); return result; } @@ -2053,7 +2050,6 @@ unsigned __int64 CKeyCursor::checkCount(unsigned __int64 max, KeyStatsCollector { reset(); unsigned __int64 result = 0; - unsigned lseeks = 0; unsigned lastFullSeg = filter->lastFullSeg(); bool unfiltered = filter->isUnfiltered(); if (lastFullSeg == (unsigned) -1) @@ -2071,7 +2067,6 @@ unsigned __int64 CKeyCursor::checkCount(unsigned __int64 max, KeyStatsCollector unsigned __int64 locount = getSequence(); endRange(lastFullSeg); _ltEqual(stats); - lseeks++; result += getSequence()-locount+1; if (max && (result > max)) break; @@ -2081,7 +2076,6 @@ unsigned __int64 CKeyCursor::checkCount(unsigned __int64 max, KeyStatsCollector else break; } - stats.noteSeeks(lseeks, 0, 0); return result; }