Итак, давайте представим простые отношения IS-A, подобные этому примеру:
create table EntityAbstract(
IDEntityAbstract int identity primary key,
Name nvarchar(50) not null,
)
create table OneOfConcreteEntity(
EntityAbstract int,
constraint PK_Image primary key (EntityAbstract),
constraint FK_Image foreign key (EntityAbstract) references EntityAbstract(IDEntityAbstract)
)
Когда я отображаю сущности из базы данных, я должен сделать их индивидуальными и уникальными объектами или я должен сделать конкретный класс, выходящий из абстрактной сущности?
например:
public class EntityAbstract
{
public int EntityAbstractID { get; set; }
public string Name { get; set; }
public EntityAbstract(int entityID, string name)
{
this.EntityAbstractID = entityID;
this.Name = name;
}
}
public class OneOfConcreatEntity : EntityAbstract
{
public OneOfConcreatEntity(int entityID, string name) : base(entityID, name){ }
}
Какой самый лучший вариант? с учетом более чем одной конкретной сущности и более сложной.