[英]DbSet.Find() doesn't work for Guid properties
我有两个模型
public class QChoice : ModelWithGuid
{
[Required]
public Guid? QId { get; set; }
}
public class ModelWithGuid
{
[Key]
public Guid Id { get; set; } = Guid.NewGuid();
}
我正在 CHOICE Dbset 上执行查找操作。
DataContext.QChoice.Find(choice => choice.QId.Value.Equals("Guid")).ToList();
从上面的行 Find Operation 调用下面的方法。
public IEnumerable<T> Find(Expression<Func<T, bool>> predicate)
{
var resultData = table.Find(predicate);//table means QChoice DbSet
yield return resultData;
}
我收到错误,如“调用 'DbSet.Find' 的位置 0 处的键值类型为 'Expression>',与 'Guid' 的属性类型不匹配”。请帮助我
根据这份文件,
EF Core DbSet<TEntity>.Find
不采用任何predicate
而是将实体的主键作为对象,如下所示:
var qChoice = DataContext.QChoice.Find(choice.QId);
此外,如果您想使用谓词进行Find
按如下方式更新您的Find
方法:
public T Find(Expression<Func<T, bool>> predicate)
{
var resultData = table.Where(predicate).FirstOrDefault();
return resultData;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.