C# 实体框架-在应用程序配置文件中找不到连接字符串

C# 实体框架-在应用程序配置文件中找不到连接字符串,c#,.net,wpf,entity-framework,mvvm,C#,.net,Wpf,Entity Framework,Mvvm,我意识到这个问题以前有人问过,也有人回答过,但我找到的答案并不完全适用于我的问题。我只有一个项目,它是一个使用实体框架的WPF(MVVM)应用程序。项目设置如下: DataEntities = new BusinessEntities(); DataEntities.C_PKE_Test.Load(); // <- Crashes here only when my teammate runs the app Collection.Source = DataEntities.C_PKE_T

我意识到这个问题以前有人问过,也有人回答过,但我找到的答案并不完全适用于我的问题。我只有一个项目,它是一个使用实体框架的WPF(MVVM)应用程序。项目设置如下:

DataEntities = new BusinessEntities();
DataEntities.C_PKE_Test.Load(); // <- Crashes here only when my teammate runs the app
Collection.Source = DataEntities.C_PKE_Test.Local;
DataEntities.C_PKE_Test.Local.CollectionChanged += Local_CollectionChanged;
Collection.SortDescriptions.Add(new SortDescription("pke_id", ListSortDirection.Ascending));

名称空间是根据文件夹结构设置的:EF_Test、EF_Test.Model和EF_Test.ViewModel。该应用程序在DataGrid中显示数据库中的数据。当我启动应用程序时,即使是在不同的机器上,它也能编译并运行良好

但是,Visual Studio抱怨XAML中的DataContext:

<Window x:Class="EF_Test.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:EF_Test"
        xmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"
        xmlns:vm1="clr-namespace:EF_Test.ViewModel"
        mc:Ignorable="d"
    Title="MainWindow" Height="350" Width="525" Loaded="Window_Loaded">
<Window.DataContext>
    <vm1:MainWindowViewModel/>
</Window.DataContext>
...
我的队友的windows事件查看器中的异常如下所示:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <configSections>
    <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  </configSections>
  <startup>
    <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.6.1" />
  </startup>
  <entityFramework>
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
      <parameters>
        <parameter value="mssqllocaldb" />
      </parameters>
    </defaultConnectionFactory>
    <providers>
      <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
    </providers>
  </entityFramework>
  <connectionStrings>
    <add name="BusinessEntities" connectionString="metadata=res://*/Model.EntityModel.csdl|res://*/Model.EntityModel.ssdl|res://*/Model.EntityModel.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=ursqldb-01;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" />
  </connectionStrings>
</configuration>
描述:由于未处理的异常,进程终止。例外情况 信息:System.Data.SqlClient.SqlException 在 System.Data.SqlClient.SqlConnection.OnError(System.Data.SqlClient.SqlException, 布尔值,系统。操作'1)在 System.Data.SqlClient.SqlInternalConnection.OnError(System.Data.SqlClient.SqlException, 布尔值,系统。操作'1)在 System.Data.SqlClient.TdsParser.ThroweException和Warning(System.Data.SqlClient.TdsParserStateObject, 布尔,布尔)在 System.Data.SqlClient.TdsParser.TryRun(System.Data.SqlClient.RunBehavior, System.Data.SqlClient.SqlCommand,System.Data.SqlClient.SqlDataReader, System.Data.SqlClient.BulkCopySimpleResultSet, System.Data.SqlClient.TdsParserStateObject,布尔ByRef)

我怀疑XAML编辑器中的投诉与我队友的用户崩溃有关。当我在代码隐藏中设置DataContext时,当我的队友运行应用程序时,应用程序不会崩溃,但DataGrid不会显示任何数据。日志消息显示,在这种情况下,语句
DataEntities.C_PKE_Test.Load()引发异常:执行命令定义时出错。有关详细信息,请参见内部异常。还有一个内部异常:对象名“dbo.\u PKE\u Test”无效


然而,该表是存在的,我们都可以在SQLManagementStudio中查询它。有人知道这里可能有什么问题吗?

这可能与分配给您的队友的模式有关

转到SQL server Management Studio中相关数据库的
安全性
节点,展开它,右键单击队友的帐户,然后点击
属性


General
页面上,您应该能够为他的帐户设置默认模式。确保它与您的匹配。

这可能与分配给您的队友的模式有关

转到SQL server Management Studio中相关数据库的
安全性
节点,展开它,右键单击队友的帐户,然后点击
属性


General
页面上,您应该能够为他的帐户设置默认模式。确保它与您的匹配。

尝试在连接字符串中将数据库名称指定为
初始目录

<add name="BusinessEntities" connectionString="metadata=res://*/Model.EntityModel.csdl|res://*/Model.EntityModel.ssdl|res://*/Model.EntityModel.msl;provider=System.Data.SqlClient;provider connection string=&quot;Data Source=ursqldb-01;Initial Catalog=YOURDATABASENAME;Integrated Security=True;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" />

尝试在连接字符串中将数据库名称指定为
初始目录

<add name="BusinessEntities" connectionString="metadata=res://*/Model.EntityModel.csdl|res://*/Model.EntityModel.ssdl|res://*/Model.EntityModel.msl;provider=System.Data.SqlClient;provider connection string=&quot;Data Source=ursqldb-01;Initial Catalog=YOURDATABASENAME;Integrated Security=True;MultipleActiveResultSets=True;App=EntityFramework&quot;" providerName="System.Data.EntityClient" />


您应该在应用程序中捕获异常,记录它,然后确定它发生的原因并解决问题。“由于未处理的异常而终止的进程”没有说明异常的实际原因。捕获它并检查InnerException.Message属性。您的意思是不在ViewModel或MainWindow构造函数中工作?我没有在我的主窗口构造函数中做任何工作。问题已更新为异常消息。dbo._PKE_Test是我们业务数据库中的一个表。该表是在SQLServerManagementStudio中设置的。我的队友和我都可以在SQLServerManagementStudio中查询表,但只有我可以在我的应用程序中显示表中的数据。当我的队友运行该应用程序时,该应用程序似乎试图查询错误的数据库(“主数据库”可能)。这是为什么?您应该在应用程序中捕获异常,记录它,然后确定它发生的原因并修复问题。“由于未处理的异常而终止的进程”没有说明异常的实际原因。捕获它并检查InnerException.Message属性。您的意思是不在ViewModel或MainWindow构造函数中工作?我没有在我的主窗口构造函数中做任何工作。问题已更新为异常消息。dbo._PKE_Test是我们业务数据库中的一个表。该表是在SQLServerManagementStudio中设置的。我的队友和我都可以在SQLServerManagementStudio中查询表,但只有我可以在我的应用程序中显示表中的数据。当我的队友运行该应用程序时,该应用程序似乎试图查询错误的数据库(“主数据库”可能)。为什么?就是这样。我以为要连接的DB名称会记录在实体框架的某个地方,就是这样。我认为要连接到的DB名称将记录在实体框架内的某个地方。虽然Juan的回答也解决了这个问题,但这有一个好处,即无论单个用户的默认模式是什么,应用程序使用的DB都指定在一个中心位置。虽然Juan的回答也解决了这个问题,这样做的好处是,无论单个用户的默认模式是什么,应用程序中要使用的数据库都在一个中心位置指定。