Android Code Snippet DBUtils 2 - New Method - HasRecords

mc73

Well-Known Member
Licensed User
Longtime User

The trick in my code is declaring a boolean, the "nextRecord".
When we set it to resultSet.nextRow, indeed the cursor moves on step forward. So, in the beginning, if no results are available, nextRecord is false. Thus, "if" statement will perform the "no records" log. So, here's the trick: If nextRecord is true, we immediately read data from the very first available position of the cursor. AFTER reading, we reset nextRecord to resultSet.nextRow and we loop. The problem with your code is that it contains a second IF, which is NOT what I've suggested, as it will obviously move on.
Let me rewrite my code:
B4X:
Private nextRecord As Boolean=res.NextRow
If Not(nextRecord) Then
   Log("no records")
Else 'why did you put another "If" here?
   Do While nextRecord
      'process
      ' you read data here. What is the initial position of our cursor here? Answer: The very first one.
      nextRecord=res.NextRow
     'the above statement should be the very last before the "loop". 
   Loop
End If
res.Close

Test:
B4X:
Private query As String="select 1 union select 2"
Private res As ResultSet=sql.ExecQuery(query)
Private nextRecord As Boolean=res.NextRow
If Not(nextRecord) Then
    Log("no records")
Else
    Do While nextRecord
       'process
       Log(res.GetString2(0))
       nextRecord=res.NextRow
    Loop
End If
res.Close

Adding a counter:
B4X:
   Private counter As Int
   Private query As String="select 1 union select 2"
   Private res As ResultSet=sql.ExecQuery(query)
   Private nextRecord As Boolean=res.NextRow
   If Not(nextRecord) Then
       Log("no records")
   Else
       Do While nextRecord
           'process
           counter=counter+1
           Log(res.GetString2(0))
           nextRecord=res.NextRow
       Loop
       Log("records="&counter)
   End If
   res.Close
 

OliverA

Expert
Licensed User
Longtime User
Another (valid) example???
I think this is a good example. Please notice that you are not using another cursor in the SUB of the example. All other examples, you are using a cursor right after the check to redo the same query that HasRecords uses. In those cases, HasRecords just duplicates the effort. In this case, it does not.
 

Harris

Expert
Licensed User
Longtime User
So, here's the trick: If nextRecord is true, we immediately read data from the very first available position of the cursor
Yes, I see that now! Very well explained.
My narrow mind couldn't see past the fact the cursor position was moving.... and MY do while WAS moving it off the only record I had...
Thanks Much!


Updated sub:
B4X:
Sub UpDateZone(txt As String)
    Dim q As String
    Dim tbl As String
    Dim Cursor As ResultSet
    Dim res As String = "Not Found!"
    If txt = "" Then
        lblzone.Text = res
        Return
    End If
    Dim sq As SQL
    If rbcan.Checked Then 
      tbl = "postal_codes" ' get names from Canadian postal codes
      sq = SQL2
    Else
      sq = SQL3   
      tbl = "zip_codes"    ' get names from USA zip codes
    End If
    q = "Select * from "&tbl&" where postal_code LIKE ('"&txt&"%') LIMIT 10"
    Cursor = sq.ExecQuery(q)
    
    Private cnt As Int = 0
    Private nextRecord As Boolean = Cursor.NextRow
    If Not(nextRecord) Then
        Log("no records")
    Else
        Log("We had (at least 1 record in result - up to LIMIT of 10 ")
            
        Do While nextRecord
            cnt = cnt + 1
            res = Cursor.GetString("place_name")&", "&Cursor.GetString("acode1")&CRLF&Cursor.GetString("aname2")
            Log("We have a record to set - count and place:  "&cnt &"  -  "&Cursor.GetString("place_name"))
            nextRecord = Cursor.NextRow
'            Exit   
        Loop
        
    End If
    Cursor.Close
    lblzone.Text = res
    
End Sub

Log Results when txt = "T". When txt = "T0B" - 1 result: Wainwright Region (Tofield) - Perfect!

B4X:
We had (at least 1 record in result - up to LIMIT of 10
We have a record to set - count and place:  1  -  Eastern Alberta (St. Paul)
We have a record to set - count and place:  2  -  Wainwright Region (Tofield)
We have a record to set - count and place:  3  -  Central Alberta (Stettler)
We have a record to set - count and place:  4  -  Western Alberta (Jasper)
We have a record to set - count and place:  5  -  North Central Alberta (Slave Lake)
We have a record to set - count and place:  6  -  Northwestern Alberta (High Level)
We have a record to set - count and place:  7  -  Southeastern Alberta (Drumheller)
We have a record to set - count and place:  8  -  International Border Region (Cardston)
We have a record to set - count and place:  9  -  Kananaskis Country (Claresholm)
We have a record to set - count and place:  10  -  Central Foothills (Sundre)
 

Harris

Expert
Licensed User
Longtime User
This thread exposes one truism ( a classic example ) :
" You (and I) may not have the definitive answer/solution - (proper, simple, or correct) "

I am always amazed with what other members come up with - when I understand the meaning of their solution.

We all get trapped into our own narrow logic. When we reach out (like this post) - we find that others may have a different way at looking at the issue.
We must thank those who "take the time" to study our posts, and offer an expert (alternative) solution (within our limited time).

With the concise explanation of @mc73 , I was able to understand an alternative method that will accomplish my desire - without additional overhead.

Thanks to all
 
Last edited:
Cookies are required to use this site. You must accept them to continue using the site. Learn more…