实体关系设计以避免递归(多对多)
Entities relationships design to avoid recursion (Many-To-Many)
我正在构建一个小应用程序,它是爱沙尼亚语-英语-爱沙尼亚语词典。英语和爱沙尼亚语单词在数据库中表示为实体(表)。每个实体都包含 word/phrase 的语言和 List<Translation language>
的翻译列表。我在它们之间有多对多的关系——这意味着许多英语单词有许多爱沙尼亚语翻译,许多爱沙尼亚语单词有许多英语翻译。 (这在我看来是合乎逻辑的)。当我使用任何一种语言获取单词并获得 JSON 表示时,我遇到了问题 - 发生无限循环,这是预期的,因为每个实体都包含相反实体的列表,而这些实体包含相反实体的列表等等。 ..
怎么可能解决这个问题?注意:我尝试将 @JsonIgnore
添加到任一侧 - 但是当我获取此侧实体时,我没有解析其他实体的列表,反之亦然。 @JsonManaged
和 @JsonBacked
也没有解决问题。我需要双方实体都得到解决但没有递归。
@Entity
@Table(name = "english_word")
public class EnglishWord {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "word")
private String word;
@ManyToMany(cascade = CascadeType.PERSIST)
@JoinTable(name = "estonian_english",joinColumns = @JoinColumn(name = "englishWord_id")
,inverseJoinColumns = @JoinColumn(name = "estonianWord_id"))
private List<EstonianWord> translations = new ArrayList<>();
public EnglishWord(String word) {
this.word = word;
}
public EnglishWord() {
}
-------------------------------------------------------------------
@Entity
@Table(name = "estonian_word")
public class EstonianWord {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "word")
private String word;
@ManyToMany(cascade = CascadeType.PERSIST)
@JoinTable(name = "estonian_english",joinColumns = @JoinColumn(name = "estonianWord_id")
,inverseJoinColumns = @JoinColumn(name = "englishWord_id"))
private List<EnglishWord> translations = new ArrayList<>();
public EstonianWord(String word) {
this.word = word;
}
public EstonianWord() {
}
您可以使用自己的 DTO 对象来表示 request/response。
我正在构建一个小应用程序,它是爱沙尼亚语-英语-爱沙尼亚语词典。英语和爱沙尼亚语单词在数据库中表示为实体(表)。每个实体都包含 word/phrase 的语言和 List<Translation language>
的翻译列表。我在它们之间有多对多的关系——这意味着许多英语单词有许多爱沙尼亚语翻译,许多爱沙尼亚语单词有许多英语翻译。 (这在我看来是合乎逻辑的)。当我使用任何一种语言获取单词并获得 JSON 表示时,我遇到了问题 - 发生无限循环,这是预期的,因为每个实体都包含相反实体的列表,而这些实体包含相反实体的列表等等。 ..
怎么可能解决这个问题?注意:我尝试将 @JsonIgnore
添加到任一侧 - 但是当我获取此侧实体时,我没有解析其他实体的列表,反之亦然。 @JsonManaged
和 @JsonBacked
也没有解决问题。我需要双方实体都得到解决但没有递归。
@Entity
@Table(name = "english_word")
public class EnglishWord {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "word")
private String word;
@ManyToMany(cascade = CascadeType.PERSIST)
@JoinTable(name = "estonian_english",joinColumns = @JoinColumn(name = "englishWord_id")
,inverseJoinColumns = @JoinColumn(name = "estonianWord_id"))
private List<EstonianWord> translations = new ArrayList<>();
public EnglishWord(String word) {
this.word = word;
}
public EnglishWord() {
}
-------------------------------------------------------------------
@Entity
@Table(name = "estonian_word")
public class EstonianWord {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(name = "word")
private String word;
@ManyToMany(cascade = CascadeType.PERSIST)
@JoinTable(name = "estonian_english",joinColumns = @JoinColumn(name = "estonianWord_id")
,inverseJoinColumns = @JoinColumn(name = "englishWord_id"))
private List<EnglishWord> translations = new ArrayList<>();
public EstonianWord(String word) {
this.word = word;
}
public EstonianWord() {
}
您可以使用自己的 DTO 对象来表示 request/response。