Search code examples
c#mysqlmysql-connectormysqldatareader

MySQL .Net Connector - MySqlReader.Read() returns false


I have some strange problem. I use MySQL Connector.NET but MySqlReader.Read() sometimes returns true and sometimes false. MySqlReader.HasRows is true both cases and in VisualStudio I can see that reader object hold all values.

Why could that happen?

Here is my code:

MySqlCommand sqlCommand = new MySqlCommand(sqlCode, this._conn);
MySqlDataReader rdr = sqlCommand.ExecuteReader();
PopulateMessage("--> " + serverName + ": " + dbName);
int fields = rdr.VisibleFieldCount;

//make headers
int[] fmaxl = new int[fields];
string[] headers = new string[fields];
List<string[]> vals = new List<string[]>();
if (rdr.HasRows)
{
        for (int hi = 0; hi < fields; hi++)
        {
                string val = rdr.GetName(hi);
                headers[hi] += val;
                fmaxl[hi] = val.Length;
        }
        while (rdr.HasRows && rdr.Read()) // <-- here the Read() method returns 
                                          //     false or true sometimes
                                          //     while HasRows is true
        {
                ...

EIDT: The rdr holds for example 99 rows with values (checked in VS) and at first call the Read() method returns false. Thanks Joachim for making me put this useful notice.


Solution

  • This HasRows property isn't in all versions of .net. Why not recast your code like this?

    boolean firstRow = true;
    while (rdr.Read()) 
    {
       if (firstRow) {   // get the column names, but only once 
           firstRow = false;
           for (int hi = 0; hi < fields; hi++)
           {
                string val = rdr.GetName(hi);
                headers[hi] += val;
                fmaxl[hi] = val.Length;
           }
        }
    
        ... //process each row.
    }
    

    Having done tonnage of this kind of stuff, I know this works pretty well.