【发布时间】:2012-07-18 19:49:47
【问题描述】:
我已经看到大多数人在使用SingleOrDefault 时都会遇到此错误。但是,我正在使用FirstOrDefault。有没有人见过这种异常现象?我正在使用存储库模式来使用依赖注入。
return context.Users.FirstOrDefault(p => p.Username.ToLower() == username.ToLower());
编辑
见下文:据我所知,错误来自 EntityFramework 的内部代码。
[InvalidOperationException: Sequence contains more than one matching element]
System.Linq.Enumerable.SingleOrDefault(IEnumerable`1 source, Func`2 predicate) +2668318
System.Data.Entity.ModelConfiguration.Conventions.IdKeyDiscoveryConventionImpl.MatchKeyProperty(EdmEntityType entityType, IEnumerable`1 primitiveProperties) +121
System.Data.Entity.ModelConfiguration.Conventions.KeyDiscoveryConvention.System.Data.Entity.ModelConfiguration.Conventions.IEdmConvention<System.Data.Edm.EdmEntityType>.Apply(EdmEntityType entityType, EdmModel model) +72
System.Data.Entity.ModelConfiguration.Conventions.IdKeyDiscoveryConvention.System.Data.Entity.ModelConfiguration.Conventions.IEdmConvention<System.Data.Edm.EdmEntityType>.Apply(EdmEntityType entityType, EdmModel model) +17
System.Data.Entity.ModelConfiguration.Configuration.EdmConventionDispatcher.Dispatch(TEdmDataModelItem item) +100
System.Data.Entity.ModelConfiguration.Configuration.EdmConventionDispatcher.VisitEdmEntityType(EdmEntityType item) +22
System.Data.Edm.Internal.DataModelItemVisitor.VisitCollection(IEnumerable`1 collection, Action`1 visitMethod) +138
System.Data.Edm.Internal.EdmModelVisitor.VisitEntityTypes(EdmNamespace edmNamespace, IEnumerable`1 entityTypes) +75
System.Data.Edm.Internal.EdmModelVisitor.VisitEdmNamespace(EdmNamespace item) +88
System.Data.Entity.ModelConfiguration.Configuration.EdmConventionDispatcher.VisitEdmNamespace(EdmNamespace item) +31
System.Data.Edm.Internal.DataModelItemVisitor.VisitCollection(IEnumerable`1 collection, Action`1 visitMethod) +138
System.Data.Edm.Internal.EdmModelVisitor.VisitNamespaces(EdmModel model, IEnumerable`1 namespaces) +75
System.Data.Edm.Internal.EdmModelVisitor.VisitEdmModel(EdmModel item) +56
System.Data.Entity.ModelConfiguration.Configuration.EdmConventionDispatcher.VisitEdmModel(EdmModel item) +44
System.Data.Entity.ModelConfiguration.Configuration.ConventionsConfiguration.ApplyModel(EdmModel model) +126
System.Data.Entity.DbModelBuilder.Build(DbProviderManifest providerManifest, DbProviderInfo providerInfo) +125
System.Data.Entity.DbModelBuilder.Build(DbConnection providerConnection) +165
System.Data.Entity.Internal.LazyInternalContext.CreateModel(LazyInternalContext internalContext) +61
System.Data.Entity.Internal.RetryLazy`2.GetValue(TInput input) +111
System.Data.Entity.Internal.LazyInternalContext.InitializeContext() +417
System.Data.Entity.Internal.InternalContext.GetEntitySetAndBaseTypeForType(Type entityType) +18
System.Data.Entity.Internal.Linq.InternalSet`1.Initialize() +63
System.Data.Entity.Internal.Linq.InternalSet`1.get_InternalContext() +15
System.Data.Entity.Infrastructure.DbQuery`1.System.Linq.IQueryable.get_Provider() +37
System.Linq.Queryable.FirstOrDefault(IQueryable`1 source, Expression`1 predicate) +63
Entities.User.GetCurrentPerson(String username, KmManagerDbContext context) in C:\Users\user\Documents\Visual Studio 2010\Projects\KmManager\Entities\User.cs:85
用户.cs
public class User
{
public long Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string Username { get; set; }
// Custom Propreties
public string FullName
{
get
{
return FirstName + " " + LastName;
}
}
public string LastNameFirst
{
get
{
return LastName + ", " + FirstName;
}
}
public static string TableName
{
get
{
return "Users";
}
}
public static User GetCurrentPerson(string username, KmManagerDbContext context)
{
try
{
// find the person who has the ad name = username
return context.Users.FirstOrDefault(p => p.Username.ToLower() == username.ToLower());
}
catch (Exception ex)
{
throw new ApplicationException("There was an error retrieving the user from the database.", ex);
}
}
}
UserConfiguration.cs
public UserConfiguration()
{
this.ToTable(User.TableName);
this.HasKey(x => x.Id);
this.Property(x => x.Id).HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
this.Property(x => x.FirstName).IsRequired();
this.Property(x => x.LastName).IsRequired();
this.Property(x => x.Username).IsRequired();
}
【问题讨论】:
-
FirstOrDefault不会抛出该消息。请提供堆栈跟踪并确保行号与上述匹配。 (还要确保没有任何编译器错误,以免意外运行可能使用过SingleOrDefault的旧代码副本) -
context.Users 或 p.Username 是否有可能在底层调用了一个集合,该集合有一个 SingleOrDefault() 被调用?
-
@BNL 您确实看到堆栈跟踪底部显示 FirstOrDefault?
-
查看堆栈跟踪的顶部 :) 有某种延迟执行正在调用
SingleOrDefault。 -
@bdparrish 您的实体数据模型在执行看似密钥检查的操作时抛出错误,表明支持您的用户实体的任何数据都包含重复的密钥。对于初学者,请在您的数据模型中发布用户实体的屏幕截图。
标签: c# entity-framework-4.1 ef-code-first