gpt4 book ai didi

c# - LinqToSql 和抽象基类

转载 作者:太空狗 更新时间:2023-10-29 21:16:04 26 4
gpt4 key购买 nike

我有一些 linq 实体继承了这样的东西:

public abstract class EntityBase { public int Identifier { get; } }

public interface IDeviceEntity { int DeviceId { get; set; } }

public abstract class DeviceEntityBase : EntityBase, IDeviceEntity
{
public abstract int DeviceId { get; set; }
}

public partial class ActualLinqGeneratedEntity : DeviceEntityBase
{
}

在通用方法中,我使用以下方法查询 DeviceEnityBase 派生实体:

return unitOfWork.GetRepository<TEntity>().FindOne(x => x.DeviceId == evt.DeviceId);

其中 TEntity 有一个限制,即它是一个 DeviceEntityBase。此查询总是失败并出现 InvalidOperationException 并显示消息“Class member DeviceEntityBase.DeviceId is unmapped”。即使我在抽象基类中添加了一些映射信息

[Column(Storage = "_DeviceId", DbType = "Int", Name = "DeviceId", IsDbGenerated = false, UpdateCheck = UpdateCheck.Never)]

最佳答案

哇,看起来这一次我可以和@MarcGravell 一起了!

我遇到了同样的问题,然后我发现了this answer ,这解决了我的问题!

在你的情况下,你会说:

return unitOfWork.GetRepository<TEntity>().Select(x => x).FindOne(x => x.DeviceId == evt.DeviceId);

Bob 是你的叔叔!

关于c# - LinqToSql 和抽象基类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/156113/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com