10

我一直在尝试使用 SQl Compact 4.0 的代码优先 EF 项目。当我尝试运行该项目时,我收到一个错误“数据库'master'中的CREATE DATABASE权限被拒绝。”。

我搜索了帮助并响应了一些博客,试图识别正在使用的连接字符串。令我惊讶的是

context.Database.Connection.ConnectionString    "Data Source=.\\SQLEXPRESS;Initial Catalog=Ancestors.Models.AncestorsContext;Integrated Security=True;MultipleActiveResultSets=True;Application Name=EntityFrameworkMUE"    string

即使我的 web.config 文件包含以下部分...

<connectionStrings>
    <add name="DefaultConnection" providerName="System.Data.SqlServerCe.4.0"    connectionString="Data Source=|DataDirectory|\aspnet-Ancestors-20121012114712.sdf" /> 
</connectionStrings>

<system.data>
<DbProviderFactories>
  <remove invariant="System.Data.SqlServerCe.4.0" />
  <add name="Microsoft SQL Server Compact Data Provider 4.0" invariant="System.Data.SqlServerCe.4.0" description=".NET Framework Data Provider for Microsoft SQL Server Compact" type="System.Data.SqlServerCe.SqlCeProviderFactory, System.Data.SqlServerCe, Version=4.0.0.1, Culture=neutral, PublicKeyToken=89845dcd8080cc91" />
</DbProviderFactories>
</system.data>

有谁知道为什么 EF 坚持创建与 SQLEXPRESS 而不是 SQL Compact 的连接?我在解决方案的任何地方都找不到对 SQLEXPRESS 的引用。

4

3 回答 3

3

而不是使用以下内容将您的连接名称传递给 DBContext

public YourContext() : base("DefaultConnection")
{

}

使用名称指令

public YourContext() : base("name=DefaultConnection")
{

}

这将告诉 EF 将该参数用作连接。

此外,在 web.config 的 connectionStrings 部分顶部添加“clear”可能会解决继承问题。

于 2014-02-12T20:21:12.820 回答
2

在您的 web.Config 中查找该<entityFramework>部分,那里应该有您的默认连接工厂:

  <entityFramework>
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework">
      <parameters>
        <parameter value="Data Source=.\SQLEXPRESS; Integrated Security=True; MultipleActiveResultSets=True"/>
      </parameters>
    </defaultConnectionFactory>
  </entityFramework>

如果您正在执行代码优先项目,您还可以更改默认构造函数以使用其他连接字符串:

public YourContext() : base("name=DefaultConnection")
{

}
于 2012-10-12T14:43:49.633 回答
1

这篇博客文章讨论了如何做到这一点......

http://blogs.msdn.com/b/davidobando/archive/2013/03/13/10339621.aspx

于 2014-01-03T11:40:38.950 回答