mamen,
Cada uno de esos errores se debe a un tipo de error muy especifico, que no puede ser resuelto con una misma solucion.
En el caso de los errores del datareader, asegurate siempre, antes de llamar el metodo read(), que el objeto command tenga una conexion asignada y que la misma este abierta. Igualmente, que al momento en el que no necesites mas la conexion, siempre cerrarla. Para esto te recomiendo usar bloques try/finally para garantizar que la conexion siempre se cerrara al ejecutarse el codigo.
El error de there's no row at position 0 tiene que ver con que cuando ejecutas el codigo, la consulta no retorna registros. Siempre valida que el Count de las filas (rows) del datatable sea > 0 antes de intentar hacer esta operacion. Lo mismo con las tablas en el dataset (if dtSet.Tables.Count > 0).
Suerte!
__________________
Héctor Geraldino
Software Engineer
|