在asp.net 2.0中,提供了更方便的配置文件访问的类,具体可以到 system.configuration 名称空间下进行查看。本文提供一种在开发过程中常用的得到数据库字符串的方法,为方便使用,写成一个方法进行调用:
public string getconnectionstring( string _connectionstringsname )
{
system.configuration.connectionstringsettingscollection config = system.configuration.configurationmanager.connectionstrings;
for (int i = 0 ; i < config.count ; i++)
{
if (config[i].name.equals(_connectionstringsname, stringcomparison.ordinalignorecase))
return config[i].tostring();
}
return string.empty;
}
如果web.config配置如下:
<connectionstrings>
<add name="connectionstring1" connectionstring="persist security info=false;user id=sa;password=;initial catalog=database1;server=(local);" providername="system.data.sqlclient"/>
<add name="connectionstring2" connectionstring="persist security info=false;user id=sa;password=;initial catalog=database2;server=(local);" providername="system.data.sqlclient"/>
</connectionstrings>
如果写成静态类方法,则可以使用下面的方法进行调用:
string connectstring = xianhuimengutil.getconnectionstring("connectionstring1");
另外,如果在遍历时进行输出,则可以看到多出来一个配置项,那是因为machine.config里已经默认定义理一个数据库连接,内容如下:
<connectionstrings>
<add name="localsqlserver" connectionstring="data source=.sqlexpress;integrated security=sspi;attachdbfilename= datadirectory aspnetdb.mdf;user instance=true" providername="system.data.sqlclient" />
</connectionstrings>
这就是许多网友在论坛上经常会问:为什么我的程序会调用 sqlexpress 数据库的原因,如果你的数据库配置不正确,或者无法打开时,就会使用 sqlexpress 数据库。
新闻热点
疑难解答
图片精选