在ASP.NET程序的多层开发中,我们常将数据访问层写在一个Class Library中。当在Class Library中使用了connection string时,很多人就发现了问题,因为Class Library最终给别人的是一个DLL,并不包含我们常见的web.config或app.config。这样的话,当我们使用的数据库需要变动时,我们就不能简单的通过修改web.config或app.config来改变connection string。
在ASP.NET程序的多层开发中,我们常将数据访问层写在一个Class Library中。当在Class Library中使用了connection string时,很多人就发现了问题,因为Class Library最终给别人的是一个DLL,并不包含我们常见的web.config或app.config。这样的话,当我们使用的数据库需要变动时,我们就不能简单的通过修改web.config或app.config来改变connection string。
不知道大家是怎么去解决这个问题的(可以share一下:)),我是这样来解决的:
1) 在建立了Class Library后,connection string会被放在app.config文件中,如:
![](https://www.cnblogs.com/Images/OutliningIndicators/ContractedBlock.gif)
Code
<connectionStrings>
<add name="TestProj.Properties.Settings.testConnectionString"
connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=test;Integrated Security=True"
providerName="System.Data.SqlClient" />
</connectionStrings>
2) 在我们的ASP.NET程序中,如果需要替换这个DLL中的connection string,我们可以在web.config中覆盖这个connection string(一定要是相同的名字),这样的话就可以达到替换的目的。如:
![](https://www.cnblogs.com/Images/OutliningIndicators/ContractedBlock.gif)
Code
<connectionStrings>
<add name="TestProj.Properties.Settings.testConnectionString"
connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=test222;Integrated Security=True"
providerName="System.Data.SqlClient" />
</connectionStrings>
此时,DLL将会使用新的database test222。问题不算太大,但是非常的实用。希望对大家有所帮助!
Have a nice day!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步