РЕДАКТИРОВАТЬ: рефакторинг, чтобы соответствовать обновленный вопрос
, потому что за содержанием EntityText есть логика, я бы предпочел полиморфизм
public abstract class Task
{
public virtual int Id { get; set; }
public abstract string Text { get; set; }
}
public class ContactTask : Task
{
public virtual Contact Contact { get; set; }
public override string Text
{
get { return Contact.FirstName + " " + Contact.LastName; }
set { Contact.FirstName = value.Split(' ')[0]; Contact.LastName = value.Split(' ')[1]; }
}
}
public class CompanyTask : Task
{
public virtual Company Company { get; set; }
public override string Text
{
get { return Company.Name; }
set { Company.Name = value; }
}
}
public class TaskMap : ClassMap<Task>
{
public TaskMap()
{
Table("TaskTable");
Id(c => c.Id, "taskID").GeneratedBy....();
DiscriminateSubclassesOn("entityType");
}
}
public class ContactTaskMap : ClassMap<ContactTask>
{
public ContactTaskMap()
{
DiscriminatorValue(3);
References(ct => ct.Contact, "entityID");
}
}
public class CompanyTaskMap : ClassMap<CompanyTask>
{
public ContactTaskMap()
{
DiscriminatorValue(2);
References(ct => ct.Company, "entityID");
}
}
// get all tasks
var all = session.QueryOver<Task>().List();
// get all tasks for Company
var companyTasks = session.QueryOver<CompanyTask>().List();