繁体   English   中英

DbSet.Find() 不适用于 Guid 属性

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM