ConfigurationSettings.AppSettings和configurationManager.connectionString

本文介绍了两种在web.config或app.config文件中设置数据库连接字符串的方法:通过connectionStrings元素直接配置连接信息和利用appSettings进行间接设置。此外,还提供了如何在C#代码中读取这些连接字符串的具体示例。

有两种方式在web.config/app.config中设置ConnectionString.

 

一种是在ConnectionString中设置

例如

XML code

 

<connectionStrings>

   <add name="ConnectionString" connectionString="Server=xxx; Port=3306; Database=xxx; uid=xxx; pwd=xxx;" />

</connectionStrings>

 

 

在代码中读取使用

C# code

 

System.Configuration.ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString

 

 

另一种是在AppSettings中设置

XML code

 

<appSettings><add key="ConnStr" value="Data Source=.\SQLEXPRESS;AttachDbFilename=C:\MyData\App_Data\Database.mdf;Integrated Security=True;User Instance=True"/></appSettings>

 

在代码中读取使用

C# code

 

 

string connStr = System.Configuration.ConfigurationManager.AppSettings["ConnStr"].ToString();

using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data; using System.Data.SqlClient; using Models; using System.Configuration; using System.Xml; namespace DAL { public class DBConfig { /// <summary> /// 禁止实例化 /// </summary> private DBConfig() { } public static List<Databases> GetDatabaseName(string connStr) { SqlConnection conn = new SqlConnection(connStr); SqlCommand cmd = new SqlCommand("select name from sys.databases where name like '%Training%'", conn); List<Databases> list = new List<Databases>(); try { conn.Open(); SqlDataReader reader = cmd.ExecuteReader(); while (reader.Read()) { list.Add(new Databases() { DatabaseName=reader[0].ToString() }); } return list; } catch (Exception ex) { throw ex; } finally { conn.Close(); } } /// 获取ConnectionStrings public static string GetConnectionStringsConfig(string connectionName) { string connectionString = ConfigurationManager.ConnectionStrings[connectionName].ConnectionString; return connectionString; } /// /// 更新连接字符串 public static void UpdateConnectionStringsConfig(string key, string conString) { bool isModified = false; //记录该连接串是否已经存在 if (ConfigurationManager.ConnectionStrings[key] != null) { isModified = true; } //新建一个连接字符串实例 ConnectionStringSettings mySettings = new ConnectionStringSettings(key, conString); // 打开可执行的配置文件*.exe.config Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); // 如果连接串已存在,首先删除它 if (isModified) { config.ConnectionStrings.ConnectionStrings.Remove(key); } // 将新的连接串添加到配置文件中. config.ConnectionStrings.ConnectionStrings.Add(mySettings); // 保存对配置文件所作的更改 config.Save(ConfigurationSaveMode.Modified); // 强制重新载入配置文件的ConnectionStrings配置ConfigurationManager.RefreshSection("connectionStrings"); } /// <summary> /// 修改AppSettings配置 /// </summary> /// <param name="key">key值</param> /// <param name="value">相应值</param> public static bool SetConfigValue(string key, string value) { try { Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); if (config.AppSettings.Settings[key] != null) config.AppSettings.Settings[key].Value = value; else config.AppSettings.Settings.Add(key, value); config.Save(ConfigurationSaveMode.Modified); ConfigurationManager.RefreshSection("appSettings"); return true; } catch { return false; } } /// <summary> /// 获取AppSettings中某一节点值 /// </summary> /// <param name="key"></param> public static string GetConfigValue(string key) { Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None); if (config.AppSettings.Settings[key] != null) return config.AppSettings.Settings[key].Value; else return string.Empty; } /// <summary> /// 测试连接数据库是否成功 /// </summary> /// <returns></returns> public static bool ConnectionTest(string ConnectionString) { //创建连接对象 SqlConnection mySqlConnection = new SqlConnection(ConnectionString); bool IsConnectionInfo = true; //ConnectionTimeout 在.net 1.x 可以设置 在.net 2.0后是只读属性,则需要在连接字符串设置 //如:server=.;uid=sa;pwd=;database=PMIS;Integrated Security=SSPI; Connection Timeout=30 //mySqlConnection.ConnectionTimeout = 1;//设置连接超时的时间 try { //Open DataBase //打开数据库 mySqlConnection.Open(); IsConnectionInfo = true; } catch { //Can not Open DataBase //打开不成功 则连接不成功 IsConnectionInfo = false; } finally { //Close DataBase //关闭数据库连接 mySqlConnection.Close(); } //mySqlConnection is a SqlConnection object if (mySqlConnection.State == ConnectionState.Closed || mySqlConnection.State == ConnectionState.Broken) { //Connection is not available return IsConnectionInfo; } else { //Connection is available return IsConnectionInfo; } } } }
07-10
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值