I believe this question was asked several months back, but i believe my situation is different and the same rules may not apply.
Everytime I execute this method tha
This is very simple ... it means that no results were returned from your query. You always have to code defensively and check to see if the Rows array has any items in it before trying to index into it. Something like:
if (dt.Rows.Count > 0)
soptype = dt.Rows[0]["SOPTYPE"].ToString();
else
somethingWentWrong();
I was having the same problem, then I realized that my first column was not integer-based. So when I edited the first I faced the same error.
So, my suggestion is either not to edit the first column or make the first column an ID column in which case you don't have to edit anything.
for (int i = 0; i <= dt.rows.count; i++)
{
// do something till rows in DT
}
you might have data in the table but I think the connection closes after the first query. try opening the connection again. Also you have string concatenation in the first SQL query, which isn't a good practice. try using block instead of try.. catch, just for a better code. And as Joel suggested, use a check