在一段 ef 查询中:c#
var query = db.Users.AsQueryable(); query = query.Where(o => !ignoreUsers.Contains(o)); // 这里用了 !Contains 来实现 not in var list = query.ToList();
出现以下异常:code
没法建立类型 Models.User 的常量值。此上下文仅支持基元类型或枚举类型。
是在查询中使用了复杂类型作in/ not in
致使的.class
把Contains
中的复杂类型,简化为简单类型再操做,好比:把User
改成UserId
.List
var query = db.Users.AsQueryable(); query = query.Where(o => !ignoreUserIds.Contains(o => o.UserId)); // 这里用了 !Contains 来实现 not in var list = query.ToList();