J'ai une chaîne de connexion comme celle-ci:
"SERVER=localhost;DATABASE=tree;UID=root;PASSWORD=branch;Min Pool Size = 0;Max Pool Size=200"
Comment en extraire les différents paramètres de la base de données? Je peux obtenir le nom de la base de données et le serveur comme ceci:
serverName = conObject.DataSource;
dbName = conObject.Database;
J'ai également besoin du nom d'utilisateur et du mot de passe. Aucune propriété n'est définie sur l'objet MySqlConnection.
À l'heure actuelle, je le fais comme ceci:
public static void GetDatabaseParameters(string connectionString, out string serverName, out string dbName, out string userName, out string password)
{
Match m = Regex.Match(connectionString, "SERVER=(.*?);DATABASE=(.*?);UID=(.*?);PASSWORD=(.*?);.*");
//serverName = m.Groups[1].Value;
//dbName = m.Groups[2].Value;
userName = m.Groups[3].Value;
password = m.Groups[4].Value;
}
Y a-t-il une pratique acceptée ici?
Vous pouvez utiliser la classe SqlConnectionStringBuilder
string conString = "SERVER=localhost;DATABASE=tree;UID=root;PASSWORD=branch;Min Pool Size = 0;Max Pool Size=200";
SqlConnectionStringBuilder builder = new SqlConnectionStringBuilder(conString);
string user = builder.UserID;
string pass = builder.Password;