无法创建类型的常量值。此上下文仅支持基元类型或枚举类型。
博客专区 > taadis 的博客 > 博客详情
无法创建类型的常量值。此上下文仅支持基元类型或枚举类型。
taadis 发表于9个月前
无法创建类型的常量值。此上下文仅支持基元类型或枚举类型。
  • 发表于 9个月前
  • 阅读 36
  • 收藏 0
  • 点赞 0
  • 评论 0

移动开发云端新模式探索实践 >>>   

摘要: 就是不写摘要.

场景重现

在一段 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();
  • 打赏
  • 点赞
  • 收藏
  • 分享
共有 人打赏支持
粉丝 0
博文 217
码字总数 35258
×
taadis
赏赏赏
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: