Estoy manteniendo algún código C# 2.0, y el programador usa un patrón de lectura de una colección de objetos comerciales al abrir un DataReader y luego pasarlo al constructor del objeto. No puedo ver nada obviamente mal con esto, pero se siente mal para mí. ¿Esto esta bien?¿Está bien pasar DataReaders a los constructores?
private static void GetObjects()
{
List<MyObject> objects = new List<MyObject>();
string sql = "Select ...";
SqlConnection connection = GetConnection();
SqlCommand command = new SqlCommand(sql, connection);
connection.Open();
SqlDataReader reader = command.ExecuteReader(CommandBehavior.CloseConnection);
while (reader.Read())
objects.Add(new MyObject(reader));
reader.Close();
}
public MyObject(SqlDataReader reader)
{
field0 = reader.GetString(0);
field1 = reader.GetString(1);
field2 = reader.GetString(2);
}
Mi ejemplo no estaba claro, pero supongamos que MyObject es una clase separada. – Sisiutl
Puedes cambiar tu código para que sea una clase ... :) –