在应用程序配置文件中找不到名为“”的连接字符串
No connectionstring named '' could be found in the application config file
我知道这个问题之前已经被问过好几次了——而且大部分的答案都是一样的。但在这些情况下,当更多项目使用相同的实体和连接字符串时,问题通常会出现在所有配置文件中。
就我而言,所有这些都在同一个项目中。并且连接字符串存在于 App.config 中。
我在 XAML:
中使用视图模型
<Window x:Class="ReportMapping.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:ReportMapping"
Title="Title" Height="477.22" Width="836.631">
<Window.DataContext>
<local:CompanyCollectionViewModel/>
</Window.DataContext>...
我正在从我的 ViewModel 调用我的实体:
namespace ReportMapping
{
class CompanyCollectionViewModel
{
NAV_HelpersEntities dbContext = new NAV_HelpersEntities();
如果我从我的视图模型所在的其他地方调用实体,它就可以工作。在代码隐藏的示例绑定中。
连接字符串(如果在 MainWindow.cs 中使用则有效):
<connectionStrings>
<add name="NAV_HelpersEntities" connectionString="metadata=res://*/Mapping.csdl|res://*/Mapping.ssdl|res://*/Mapping.msl;provider=System.Data.SqlClient;provider connection string="data source=NAV\;initial catalog=NAV_Helpers;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework"" providerName="System.Data.EntityClient" />
</connectionStrings>
这里是 NAV_HelpersEntities 构造函数:
public partial class NAV_HelpersEntities : DbContext
{
public NAV_HelpersEntities()
: base("name=NAV_HelpersEntities")
{
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
throw new UnintentionalCodeFirstException();
}
public virtual DbSet<R_Component> R_Component { get; set; }
public virtual DbSet<R_Configuration> R_Configuration { get; set; }
public virtual DbSet<R_Masterdata> R_Masterdata { get; set; }
public virtual DbSet<R_Type> R_Type { get; set; }
public virtual DbSet<View_NAV_Entries> View_NAV_Entries { get; set; }
public virtual DbSet<View_R_GetAccounts> View_R_GetAccounts { get; set; }
}
当我调试 CompanyCollectionViewModel 构造函数时,我可以看到正在填充我的 ObservableCollection。
我做错了什么?
更新:
好吧,我现在通过将连接字符串添加到 machine.config 来让它工作。这行得通 - 但我想这只是我稍后必须解决的一种解决方法。感谢您的输入。
我找到了一个简单的解决方案。调用实体构造函数的基构造函数时,必须从参数字符串中删除 "name=" 。
所以你必须改变这个:
public partial class SalesContext : DbContext
{
public SalesContext()
: base("name=SalesContext")
{
}
对此:
public partial class SalesContext : DbContext
{
public SalesContext()
: base("SalesContext")
{
}
改变这个:
base("name=NAV_HelpersEntities")
对此:
base(nameOrConnectionString: "NAV_HelpersEntities")
我知道这个问题之前已经被问过好几次了——而且大部分的答案都是一样的。但在这些情况下,当更多项目使用相同的实体和连接字符串时,问题通常会出现在所有配置文件中。 就我而言,所有这些都在同一个项目中。并且连接字符串存在于 App.config 中。 我在 XAML:
中使用视图模型<Window x:Class="ReportMapping.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:ReportMapping"
Title="Title" Height="477.22" Width="836.631">
<Window.DataContext>
<local:CompanyCollectionViewModel/>
</Window.DataContext>...
我正在从我的 ViewModel 调用我的实体:
namespace ReportMapping
{
class CompanyCollectionViewModel
{
NAV_HelpersEntities dbContext = new NAV_HelpersEntities();
如果我从我的视图模型所在的其他地方调用实体,它就可以工作。在代码隐藏的示例绑定中。
连接字符串(如果在 MainWindow.cs 中使用则有效):
<connectionStrings>
<add name="NAV_HelpersEntities" connectionString="metadata=res://*/Mapping.csdl|res://*/Mapping.ssdl|res://*/Mapping.msl;provider=System.Data.SqlClient;provider connection string="data source=NAV\;initial catalog=NAV_Helpers;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework"" providerName="System.Data.EntityClient" />
</connectionStrings>
这里是 NAV_HelpersEntities 构造函数:
public partial class NAV_HelpersEntities : DbContext
{
public NAV_HelpersEntities()
: base("name=NAV_HelpersEntities")
{
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
throw new UnintentionalCodeFirstException();
}
public virtual DbSet<R_Component> R_Component { get; set; }
public virtual DbSet<R_Configuration> R_Configuration { get; set; }
public virtual DbSet<R_Masterdata> R_Masterdata { get; set; }
public virtual DbSet<R_Type> R_Type { get; set; }
public virtual DbSet<View_NAV_Entries> View_NAV_Entries { get; set; }
public virtual DbSet<View_R_GetAccounts> View_R_GetAccounts { get; set; }
}
当我调试 CompanyCollectionViewModel 构造函数时,我可以看到正在填充我的 ObservableCollection。
我做错了什么?
更新: 好吧,我现在通过将连接字符串添加到 machine.config 来让它工作。这行得通 - 但我想这只是我稍后必须解决的一种解决方法。感谢您的输入。
我找到了一个简单的解决方案。调用实体构造函数的基构造函数时,必须从参数字符串中删除 "name=" 。 所以你必须改变这个:
public partial class SalesContext : DbContext
{
public SalesContext()
: base("name=SalesContext")
{
}
对此:
public partial class SalesContext : DbContext
{
public SalesContext()
: base("SalesContext")
{
}
改变这个:
base("name=NAV_HelpersEntities")
对此:
base(nameOrConnectionString: "NAV_HelpersEntities")