La lista <T> sobrescribe todos los elementos dentro de un bucle foreach al último valor
Estoy tratando de crear una aplicación de Windows en la que hay un cuadro combinado y durante la carga (), estoy completando este cuadro combinado con todas las cadenas de conexión disponibles en mi archivo de configuración de aplicación.
Aquí está la aplicación Fragmento de configuración:
<!-- Adding Multiple Servers in Connection String-->
<connectionStrings>
<add name="SQLConnect-1"
connectionString="Data Source=SAHIL; Initial Catalog=RecordComparisonTool; Integrated Security=SSPI"
providerName="System.Data.SqlCLient"/>
<add name="SQLConnect-2"
connectionString="Data Source=SAHIL; Initial Catalog=RecordComparisonTool; User Id=test; Password=12123; Integrated Security=SSPI"
providerName="System.Data.SqlCLient"/>
<add name="SQLConnect-3"
connectionString="Data Source=SAHIL; Initial Catalog=RecordComparisonTool; User Id=test; Password=32315; Integrated Security=True"
providerName="System.Data.SqlCLient"/>
</connectionStrings>
He creado una clase CompareResult en la que intento obtener todos los valores de la aplicación, configurarlos y mostrarlos en el cuadro combinado.
namespace RecordComparisonTool_Win
{
public class ConnectionString
{
public string name { get; set; }
public string conString { get; set; }
public string provider { get; set; }
}
public class CompareResult
{
public List<ConnectionString> GetConnection()
{
List<ConnectionString> conStr = new List<ConnectionString>();
ConnectionString conn = new ConnectionString();
foreach (ConnectionStringSettings css in ConfigurationManager.ConnectionStrings)
{
if (!(css.Name == "LocalSqlServer" || css.Name == "LocalMySqlServer"))
{
conn.name = css.Name;
conn.conString = css.ConnectionString;
conn.provider = css.ProviderName;
conStr.Add(conn);
}
}
return conStr;
}
}
}
El problema es que cuando intento vincularlo con el cuadro combinado, muestra tres registros según el archivo app.Config, pero todos los registros tienen el mismo valor que "SQLConnect-3". No puedo encontrar la razón por la cual la Lista se actualizó con "SQLConnect-3" para todos los registros. Por favor, ayuda a corregir el error. Aquí está el fragmento donde estoy vinculando esta lista a ComboBox
protected void LoadConnection()
{
CompareResult compareResult = new CompareResult();
List<ConnectionString> connectionString = new List<ConnectionString>();
connectionString = compareResult.GetConnection();
cbTokenLeft.DataSource = connectionString;
cbTokenLeft.DisplayMember = "name";
cbTokenLeft.ValueMember = "conString";
}