一尘不染

SQL Express连接字符串:相对于应用程序位置的mdf文件位置

c#

我将SQL Express数据库用作c#中的单元测试项目的一部分。我的数据库位于这里:

./Databases/MyUnitTestDB.mdf

我想在中使用相对路径或变量,app.config而不是将我的连接字符串定义为:

AttachDbFilename=C:\blah\blah\blah\yea\yea\yea\MyApplication\Databases\MyUnitTestDB.mdf

我已经看到了的用法,|DataDirectory|但是我认为这仅适用于Web应用程序吗?

我想在应用程序配置文件中对此进行控制,因为在生产中,该应用程序使用托管的sql数据库。


阅读 268

收藏
2020-05-19

共1个答案

一尘不染

谢谢大家,我结合了您的回答。

在我的app.config文件中,我的连接字符串定义如下

<add name="MyConnectionString"
    connectionString="Server=.\SQLExpress;AttachDbFilename=|DataDirectory|\MyDatabase.mdf;Database=MyDatabaseForTesting;Trusted_Connection=Yes;" />

在我的单元测试类中,我使用以下命令设置DataDirectory属性

[TestInitialize]
public void TestInitialize()
{
    AppDomain.CurrentDomain.SetData("DataDirectory", System.IO.Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Databases"));

    // rest of initialize implementation ...
}
2020-05-19