2

因此,我按照 ADO.NET 团队博客中的说明尝试制作了一个小型测试项目。我已经仔细检查了一切。它似乎不起作用,并一直说连接字符串丢失。

http://blogs.msdn.com/b/adonet/archive/2011/03/15/ef-4-1-model-amp-database-first-walkthrough.aspx

步。1 构建此 UserModels.dll。在dll,App.Config文件中,edmx生成了这个连接字符串:(制作的时候点击'test'按钮,连接成功,生成了'UserDatabase'所有表的edmx图)

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <connectionStrings>
    <add name="UserModelsContainer" connectionString="metadata=res://*/UserModels.csdl|res://*/UserModels.ssdl|res://*/UserModels.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=MyDesktop\SQL2008;initial catalog=UserDatabase;integrated security=True;multipleactiveresultsets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" />
  </connectionStrings>
</configuration>

Step 2. 然后我做了一个测试项目:

class UnitTetst1 ....
TestMethod1()....
using (var db = new UserModelsContainer()) {
  int i = db.Users.Count(); // <---expecting '0' for a new db, but I get an exception
}

---------这里的问题-----

步骤 3. 运行测试。然后我得到一个像这样的错误 InvalidOperationException:

"No connection string named 'UserModelsContainer' could be found in the application config file."

似乎 DbContext 不知道从 App.Config 中获取 connectionStrings 的位置?

请帮忙~~

4

2 回答 2

7

运行程序时,读取的是正在运行的 .exe 文件的 app.config。.dll 的 app.config 从未使用过。由于 UserModel.dll 是一个 dll,因此您必须在某个地方运行一个 .exe(或网站)。将连接字符串放在该 exe 的 app.config 中(或者如果它是 web.config 中的网站)。

于 2012-05-27T06:36:38.393 回答
5

当我尝试从“包管理器控制台”执行更新数据库命令时遇到了这个问题。我有一个单独的项目用于我的代码第一数据访问层和另一个用于我的 Web 项目等

我正在使用以下命令:“update-database -projectname MYPROJECTDANAME -CONNECTIONSTRINGNAME CONNECTIONSTRING -Force”

所以它指向我的 MYPROJECTDANAME 项目,但是它从您指定的启动项目中获取连接字符串名称。因此,请确保您标记为启动项目的项目具有所需的连接字符串。

于 2013-09-10T18:52:17.520 回答