Двухсторонняя ассоциация «один ко многим» в NHibernate - PullRequest
0 голосов
/ 16 сентября 2011

С помощью NHibernate, как заставить user.AddPost(post) и post.setAuthor(user) вести себя одинаково?

Вот мои классы:

public class User
{
    public virtual int Id { get; set; }
    public virtual string Name { get; set; }
    public virtual int Age { get; set; }

    private ICollection<Post> _posts = new HashSet<Post>();
    public virtual ICollection<Post> Posts
    {
        get { return _posts; }
        set { _posts = value; }
    }

    public override string ToString()
    {
        return string.Format("User{{id={0}, name='{1}', age={2}}}", Id, Name, Age);
    }
}

public class Post
{
    public virtual int Id { get; set; }
    public virtual string Text { get; set; }
    public virtual User Author { get; set; }

    public override string ToString()
    {
        return string.Format("Post{{id={0}, text='{1}', author={2}}}", Id, Text, Author);
    }
}

Вот мои сопоставления:

<class name="User" table="users">
  <id name="Id" type="int">
    <column name="Id" not-null="true" />
    <generator class="native"/>
  </id>
  <property name="Name" column="Name" />
  <property name="Age" column="Age" />
  <set name="Posts" inverse="true">
    <key column="AuthorId" />
    <one-to-many class="Post" />
  </set>
</class>

<class name="Post" table="posts">
  <id name="Id" type="int">
    <column name="Id" not-null="true" />
    <generator class="native"/>
  </id>
  <property name="Text" column="Text" />
  <many-to-one name="Author" column="AuthorId" class="User" />
</class>

Рабочий код (работает нормально):

var user = new User {
  Name = "loki2302",
  Age = 100
};
session.Save(user);

var post = new Post {
  Text = "qwerty",
  Author = user
};
session.Save(post);

Возможно ли также включить этот подход (не работает):

var user = new User {
  Name = "loki2302",
  Age = 100
};
session.Save(user);

var post = new Post {
  Text = "qwerty"
};
user.Posts.Add(post);
session.save(user);

?

Ответы [ 2 ]

3 голосов
/ 16 сентября 2011

Я полагаю, что это не удается из-за ограничения NOT NULL на столбец автора?Вы не устанавливаете свойство Author в Post, поэтому NHibernate вставляет NULL в столбец внешнего ключа.

Если вам нужны двусторонние отношения, создайте метод User.AddPost(Post), в который вы добавляетеотправьте сообщение в коллекцию и установите его свойство Author.

Если вам нужен только набор в вашем коде (но не ссылка Author), просто удалите свойство Author (и его отображение), удалите inverse="true" своего отображения коллекции и добавьте not-null="true" к элементу key своего отображения коллекции.Таким образом, коллекция будет обрабатывать ссылку от Post до User.

1 голос
/ 16 сентября 2011

Насколько я понял, вам нужно настроить параметры каскадирования для сущности пользователя.

...