Solved

GetRows returns an array with ubound -1

Posted on 2002-06-06
3
776 Views
Last Modified: 2008-01-09
The recordset returned has only one record.  Stepping through the code shows the recordcount as 1 (correctly) when this is executed:
    rs.MoveLast
    ....

    If xErr = 3021 Then
        fExtractDataByStore = 0
    Else
        rs.MoveFirst
        vData = rs.GetRows(rs.RecordCount)
        fExtractDataByStore = rs.RecordCount
        Debug.Print LBound(vdata, 1), Ubound(vdata, 1)
        Debug.Print LBound(vdata, 2), Ubound(vdata, 2)
    End If

The debug output looks like this:
0 -1
0 7

The recordset has no problems, all the fields have data, but the GetRows is not returning useful information.

This is confusing me.
0
Comment
Question by:PaulHews
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
3 Comments
 
LVL 5

Accepted Solution

by:
rpai earned 100 total points
ID: 7060119
Works fine for me.
I tried the following lines of code:-
Dim vData As Variant
vData = rs.GetRows(1)
Debug.Print LBound(vData, 1), UBound(vData, 1)
Debug.Print LBound(vData, 2), UBound(vData, 2)

The debug output looks like this:-
 0             8 (My recordset has 8 fields)
 0             0
0
 
LVL 38

Author Comment

by:PaulHews
ID: 7060131
I also tried hardcoding the NumRows parameter and tried compacting the database incase recordcount was doing something funny.  Still the weird ubound.
0
 
LVL 38

Author Comment

by:PaulHews
ID: 7060165
Just found the problem.  Had an expression in one of the selected fields that evaluated to a division by zero on this particular run.  It didn't cough up any errors other than the messed up GetRows (although trying to inspect that particular field did give me a "duplicate definition" error, weird, huh?)  Solved it using an IIF function in the expression.  Thanks for trying to help here, I appreciate it.
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Article by: Martin
Here are a few simple, working, games that you can use as-is or as the basis for your own games. Tic-Tac-Toe This is one of the simplest of all games.   The game allows for a choice of who goes first and keeps track of the number of wins for…
I was working on a PowerPoint add-in the other day and a client asked me "can you implement a feature which processes a chart when it's pasted into a slide from another deck?". It got me wondering how to hook into built-in ribbon events in Office.
Get people started with the process of using Access VBA to control Excel using automation, Microsoft Access can control other applications. An example is the ability to programmatically talk to Excel. Using automation, an Access application can laun…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…
Suggested Courses
Course of the Month9 days, 9 hours left to enroll

623 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question