我意识到这个问题之前已经被问过并得到了回答,但我发现的答案并不适用于我的问题。我只有一个项目,这是一个使用Entity Framework的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="data source=ursqldb-01;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework"" providerName="System.Data.EntityClient" />
</connectionStrings>
</configuration>
正如我所说,该项目编译并运行(对我而言)。然而,我的队友在创业时遇到了崩溃。他在像我这样的数据库上具有完全相同的权限,实体框架设置为使用Windows身份验证连接到数据库。当他启动应用程序时,它会在ViewModel构造函数中的DataEntities.C_PKE_Test.Load();
处崩溃。我按如下方式在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.SqlException 在 System.Data.SqlClient.SqlConnection.OnError(System.Data.SqlClient.SqlException, Boolean,System.Action&#39; 1)at System.Data.SqlClient.SqlInternalConnection.OnError(System.Data.SqlClient.SqlException, Boolean,System.Action&#39; 1)at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(System.Data.SqlClient.TdsParserStateObject, 布尔值,布尔值)at 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,Boolean ByRef) ...
我怀疑XAML编辑器中的投诉和我队友用户的崩溃已经连接。当我在代码中设置DataContext时,应用程序不会崩溃,但是当我的队友运行应用程序时,DataGrid不会显示任何数据。记录消息显示在此方案中,语句DataEntities.C_PKE_Test.Load();
引发异常:执行命令定义时发生错误。有关详细信息,请参阅内部异常。还有一个内部异常:无效的对象名称&#39; dbo._PKE_Test
然而表存在,我们都可以在SQL Management Studio中查询它。有谁知道这里有什么问题?
答案 0 :(得分:1)
这可能与您的队友所分配的架构有关。
转到SQL Server Management Studio中相关数据库的Security
节点,展开它,右键单击您队友的帐户并点击Properties
。
在General
页面上,您应该可以为其帐户设置默认架构。确保它与你的相符。
答案 1 :(得分:1)
尝试在连接字符串中将数据库的名称指定为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="Data Source=ursqldb-01;Initial Catalog=YOURDATABASENAME;Integrated Security=True;MultipleActiveResultSets=True;App=EntityFramework"" providerName="System.Data.EntityClient" />