Выбор столбца из нескольких условных таблиц с помощью NHibernate - PullRequest
0 голосов
/ 14 декабря 2011

У меня есть класс сущности, который имеет 3 столбца;entityType, entityID и EntityText.Я хочу заполнить столбец entityText из 3 условных таблиц. Например: если тип сущности равен 3 (contact), а entityID равен 2, он присоединится к таблице контактов и получит контакт по entityID и установит свойство contact.name в качестве EntityText.Как я могу это сделать?

Подробности: Не тот же класс объекта.

Contact
{
contactID
firstName
lastName
..
}
Company
{
companyID
name
address
...
}
 Task{
taskID
entityID
entityType
entityText= Company.name or Contact.firstName + Contact.lastName
...
}

1 Ответ

0 голосов
/ 14 декабря 2011

РЕДАКТИРОВАТЬ: рефакторинг, чтобы соответствовать обновленный вопрос

, потому что за содержанием 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();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...