Java StackOverflower错误发生在我尝试进行JPQL连接查询时
我拥有以下实体:Java StackOverflower错误发生在我尝试进行JPQL连接查询时,java,join,spring-data-jpa,stack-overflow,jpql,Java,Join,Spring Data Jpa,Stack Overflow,Jpql,我拥有以下实体: @Data @Entity @Table(name = "artist") public class Artist { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @Column(name="artist_id") private int id; @Column(name="artist_name", length = 2000) private String n
@Data
@Entity
@Table(name = "artist")
public class Artist {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="artist_id")
private int id;
@Column(name="artist_name", length = 2000)
private String name;
private String country;
@OneToMany(mappedBy = "artist", cascade = CascadeType.ALL, fetch = FetchType.EAGER)
private List<Song> songs = new ArrayList<>();
public Artist(String name, String country){
this.name=name;
this.country=country;
}
}
@Data
@Entity
@Table(name = "songs")
public class Song {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int songId;
@Column(name = "text", length = 65600)
private String text;
private Double rating;
private String songName;
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "artist_id", nullable = false)
public Artist artist;
public Song(String text, Double rating, String songName, Artist artist) {
this.text = text;
this.rating = rating;
this.songName = songName;
this.artist = artist;
}
}
解决此问题的正确方法是什么?这几乎可以肯定是由您使用和
@Data
注释引起的,该注释是其他Lombok注释的快捷方式:
@ToString、@EqualsAndHashCode、@Getter(所有字段)、@Setter(所有非最终字段)和@RequiredArgsConstructor
@ToString
注释将自动生成一个包含所有字段的ToString
方法。堆栈跟踪的底部指向集合上的toString
方法调用,如果跟踪堆栈,则可以发现导致堆栈溢出的循环:
AbstractCollection.toString
->Song.toString
->Artister.toString
->AbstractCollection.toString
->Song.toString
您的艺术家
实体包含一组歌曲
实体,这些实体包含对艺术家
实体的引用,依此类推。您可以看到它在调用toString
方法时如何陷入循环,并最终耗尽堆栈帧/达到极限
要么删除
@Data
注释,只应用子集,要么定义自己的toString
方法以避免循环。是的,这是真的。谢谢,你的回答很有帮助!
@Query("SELECT a FROM Artist a JOIN FETCH a.songs s WHERE s.songName LIKE CONCAT('%',:pattern,'%')")
List<Artist> findBySong(@Param("pattern") String songName);
>
>
> Caused by: java.lang.StackOverflowError: null
> at sun.misc.FloatingDecimal$BinaryToASCIIBuffer.dtoa(FloatingDecimal.java:431)
> ~[na:1.8.0_151]
> at sun.misc.FloatingDecimal$BinaryToASCIIBuffer.access$100(FloatingDecimal.java:259)
> ~[na:1.8.0_151]
> at sun.misc.FloatingDecimal.getBinaryToASCIIConverter(FloatingDecimal.java:1785)
> ~[na:1.8.0_151]
> at sun.misc.FloatingDecimal.getBinaryToASCIIConverter(FloatingDecimal.java:1738)
> ~[na:1.8.0_151]
> at sun.misc.FloatingDecimal.toJavaFormatString(FloatingDecimal.java:70)
> ~[na:1.8.0_151]
> at java.lang.Double.toString(Double.java:204) ~[na:1.8.0_151]
> at java.lang.Double.toString(Double.java:644) ~[na:1.8.0_151]
> at java.lang.String.valueOf(String.java:2994) ~[na:1.8.0_151]
> at java.lang.StringBuilder.append(StringBuilder.java:131) ~[na:1.8.0_151]
> at com.music.entity.Song.toString(Song.java:8) ~[classes/:na]
> at java.lang.String.valueOf(String.java:2994) ~[na:1.8.0_151]
> at java.lang.StringBuilder.append(StringBuilder.java:131) ~[na:1.8.0_151]
> at java.util.AbstractCollection.toString(AbstractCollection.java:462)
> ~[na:1.8.0_151]
> at org.hibernate.collection.internal.PersistentBag.toString(PersistentBag.java:510)
> ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
> at java.lang.String.valueOf(String.java:2994) ~[na:1.8.0_151]
> at java.lang.StringBuilder.append(StringBuilder.java:131) ~[na:1.8.0_151]
> at com.music.entity.Artist.toString(Artist.java:9) ~[classes/:na]
> at java.lang.String.valueOf(String.java:2994) ~[na:1.8.0_151]
> at java.lang.StringBuilder.append(StringBuilder.java:131) ~[na:1.8.0_151]
> at com.music.entity.Song.toString(Song.java:8) ~[classes/:na]
> at java.lang.String.valueOf(String.java:2994) ~[na:1.8.0_151]
> at java.lang.StringBuilder.append(StringBuilder.java:131) ~[na:1.8.0_151]
> at java.util.AbstractCollection.toString(AbstractCollection.java:462)
> ~[na:1.8.0_151]