string connectionString = ConfigurationManager.AppSettings["AllRttpDBConnectionString"];
MySqlConnection connection = new MySqlConnection(connectionString);
MySqlCommand command = connection.CreateCommand();
command.CommandText = "Select * from test where ServiceName like 'T%' " ;
try
{
connection.Open();
}
catch (Exception e)
{
Console.WriteLine(e.ToString());
}
try
{
MySqlDataReader reader;
reader = command.ExecuteReader();
while (reader.Read())
{
Player.Name = reader["Name"].ToString();
Player.Number = Convert.ToInt32(reader["Number"].ToString());
//push to list
PlayerList.Add(Player);
}
connection.Close();
}
catch (Exception e)
{
connection.Close();
logger.Info(e.ToString());
}
Выше приведен код, который я использую для чтения нескольких строк из базы данных в список. Однако все мои элементы списка имеют одни и те же данные (последняя строка базы данных).Чтение нескольких строк из базы данных - Где я ошибаюсь?
Я знаю, что это, вероятно, очень простая, глупая ошибка, но я просто не вижу ее.
oh ... Я предположил, что он перезаписывает значения на каждой итерации цикла. Думаю, я был неправ. Позвольте мне попробовать ваше решение. – xbonez
Это перезапись значений на каждой итерации, проблема в том, что вы добавляете один и тот же экземпляр снова и снова, потому что это тот же самый экземпляр, когда вы обновляете значение во время чтения, каждый элемент в списке обновляется, потому что все они являются тот же экземпляр объекта. – Daniel
Спасибо. Это работает! – xbonez