无法创建类型的常量值。此上下文仅支持基元类型或枚举类型。
场景重现
在一段 ef 查询中:
var query = db.Users.AsQueryable();
query = query.Where(o => !ignoreUsers.Contains(o)); // 这里用了 !Contains 来实现 not in
var list = query.ToList();
出现如下异常:
无法创建类型 Models.User 的常量值。此上下文仅支持基元类型或枚举类型。
问题原因
是在查询中使用了复杂类型做in/ not in导致的.
解决办法
把Contains中的复杂类型,简化为简单类型再操作,比如:把User改为UserId.
var query = db.Users.AsQueryable();
query = query.Where(o => !ignoreUserIds.Contains(o => o.UserId)); // 这里用了 !Contains 来实现 not in
var list = query.ToList();
    [支持/订阅](https://afdian.com/a/taadis)作者,以获得更多服务.
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号