繁体   English   中英

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

[英]Entity Framework - No connection string could be found in the application config file

我知道之前曾有人问过这个问题,但我发现的答案并不完全适用于我的问题。 我只有一个项目 ,它是使用实体框架的WPF(MVVM)应用程序。 该项目的设置如下:

项目概况

命名空间是根据文件夹结构设置的: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>
...

<vm1:MainWindowViewModel/>它说在应用程序配置文件中找不到连接字符串...。 App.config看起来像这样:

<?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>

正如我所说,该项目可以编译并运行(对我来说)。 但是我的队友在启动时遇到崩溃。 他像我一样在数据库上拥有完全相同的权利,并且将实体框架设置为使用Windows身份验证连接到数据库。 当他启动应用程序时,它在DataEntities.C_PKE_Test.Load();崩溃DataEntities.C_PKE_Test.Load(); 在ViewModel构造函数中。 我将数据加载到ViewModel构造函数中,如下所示:

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));

我队友的Windows事件查看器中的异常如下所示:

说明:由于未处理的异常,进程终止了。 异常信息:System.Data.SqlClient.SqlConnection.OnError上的System.Data.SqlClient.SqlException(System.Data.SqlClient.SqlInternalConnection.OnError(System.Data.SqlClient.SqlConnection.OnError(System.Data.SqlClient.SqlException,Boolean,System.Action'1)。 System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(System.Data.SqlClient.TdsParserStateObject,Boolean,Boolean)处的Data.SqlClient.SqlException,布尔值,System.Action'1)。 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._PKE_Test

该表仍然存在,我们都可以在SQL Management Studio中查询它。 有谁知道这里可能有什么问题吗?

这可能与队友分配给的架构有关。

转到SQL Server Management Studio中有问题的数据库的“ Security节点,将其展开,右键单击您队友的帐户,然后单击“ Properties

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

尝试在连接字符串中将数据库的名称指定为Initial Catalog

<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" />

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM