Как создать @Entity с отношениями родитель / ребенок - PullRequest
0 голосов
/ 06 июля 2010

Я создаю сайт, на котором будут статьи;каждая статья будет иметь комментарии.Эти комментарии будут сохранены в таблице «comment» с полем «parent_id», который является внешним ключом к полю «id» в той же таблице.

Я надеюсь использовать Hibernate, чтобы рекурсивно получить все комментарии для конкретной статьи.

Вот моя сущность:

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import org.hibernate.annotations.IndexColumn;

@Entity
public class Comment implements Serializable {
    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    private int id;
    @ManyToOne
    @JoinColumn(name="user_id")
    private User user;
    @OneToMany(targetEntity=Comment.class)
    @JoinColumn(name="parent_id")
    @IndexColumn(name="id", base=0)
    private List<Comment> comments = new ArrayList<Comment>();
    @Column(name="article_id", length=10)
    private int articleId;
    @Column(name="text", length=8192)
    private String text;

    public int getArticleId() {
        return articleId;
    }

    public void setArticleId(int articleId) {
        this.articleId = articleId;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }



    public String getText() {
        return text;
    }

    public void setText(String text) {
        this.text = text;
    }

    public User getUser() {
        return user;
    }

    public void setUser(User user) {
        this.user = user;
    }

    @Override
    public String toString() {
        return "Comment [" + "articleId " + articleId + " " + "id " + id + " "  + "text " + text + " " + "]";
    }


}

Код "своего рода" работает, однако, когда все комментарии получены, дочерний список комментариев содержит одинаковое количество элементовтак как есть общее количество комментариев (если это имеет смысл. Например, предположим, у меня есть только три комментария в таблице для статьи с идентификатором № 1 ... эта статья с 2 комментариями, и один из комментариев имеет дочерний комментарий ..В массиве с дочерним комментарием есть 3 записи, первые 2 - нулевые, а последний - дочерний комментарий.

Правильно ли указан этот код?

1 Ответ

2 голосов
/ 06 июля 2010

Интересно, проблема не в том, что вы используете столбец PK в качестве столбца индекса.Я бы рекомендовал использовать выделенный столбец для столбца индекса.Примерно так:

@OneToMany
@JoinColumn(name="parent_id")
@IndexColumn(name="comments_index", base=0)
private List<Comment> comments = new ArrayList<Comment>();

Не могли бы вы попробовать?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...