Nhibernate One-to-One Mapping по кодуC#

Место общения программистов C#
Ответить
Anonymous
 Nhibernate One-to-One Mapping по коду

Сообщение Anonymous »

Я пытаюсь определить способ отобразить один к одному отношению в nhibernate, когда столбец ссылки не является столбцом первичного ключа на второй таблице. < /p>

Например, рассмотрите < /p>

Person Table
PersonId (pk)
Name
< /code>

и < /p>

Passport Table
PassportId (pk)
Country
PersonId
< /code>

Две таблицы имеют одну к одному отношению к Personid. < /p>

Моя модель Nhibernate выглядит ниже. < /p>

public class Person
{
public virtual int Id { get; set; }
public virtual string Name { get; set; }
public virtual Passport Passport { get; set; }
}

public class Passport
{
public virtual int Id { get; set; }
public virtual string Country { get; set; }
public virtual Person Person { get; set; }
}
< /code>

На основе формы объяснения этой статьи я определил отображение отношений следующим образом, но она не работала < /p>

Personmapping: < /p>

OneToOne(x => x.Passport, x => x.Cascade(Cascade.All));
< /code>

passportmapping: < /p>

ManyToOne(x => x.Person, x => { x.Unique(true); x.Column("PersonId");});
< /code>

Он строит запрос SQL следующим образом < /p>

select * from Person
left outer join Passport on Persson.PersonId = Passport.PassportId.
< /code>

Это предполагает, что Passportid и Personid имеют одинаковое значение, но в моем случае они разные. Как я могу определить свое отображение в таком случае, используя отображение по коду.

Подробнее здесь: https://stackoverflow.com/questions/259 ... ng-by-code
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»