Hibernate: MultipleBagFetchException während der SessionFactory-Erstellung beheben
Bei Verwendung von Hibernate kann es bei der SessionFactory-Erstellung zu einer Ausnahme kommen:
org.hibernate.loader.MultipleBagFetchException: cannot simultaneously fetch multiple bags
Dies wird normalerweise verursacht, wenn mehrere Entitätssammlungen eifrig abgerufen werden (mit FetchType.EAGER) innerhalb einer Entität. Dies kann zu Leistungsproblemen, Dateninkonsistenzen und Speicheraufwand führen.
Testfall:
Betrachten Sie das folgende Beispiel:
@Entity public class Parent { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @OneToMany(mappedBy = "parent", fetch = FetchType.EAGER) private List<Child> children; } @Entity public class Child { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @ManyToOne private Parent parent; }
In In diesem Fall wird beim Abrufen von Parent.children eifrig versucht, mehrere untergeordnete Sammlungen gleichzeitig abzurufen, was zu dem führt Ausnahme.
Mögliche Lösungen:
1. FetchType.EAGER entfernen:
FetchType.EAGER aus der Parent.children-Zuordnung entfernen. Dies führt dazu, dass Hibernate die untergeordneten Elemente bei Bedarf langsam abruft, wodurch die Ausnahme behoben wird. Es kann jedoch die Leistung beeinträchtigen.
2. Verwenden Sie LazyCollection:
Annotieren Sie das Kinderfeld mit @LazyCollection(LazyCollectionOption.FALSE), anstatt FetchType.EAGER zu verwenden. Dies weist Hibernate an, die Sammlung eifrig zu laden, jedoch über einen verzögerten Initialisierungsprozess, um die Ausnahme zu vermeiden.
3. Verwenden Sie ein Set:
In den meisten Fällen ist es vorzuziehen, Set
Achtung:
Die Verwendung von Sätzen beseitigt nicht das zugrunde liegende Problem mit dem kartesischen Produkt diskutiert von Vlad Mihalcea. Allerdings ist es im Allgemeinen ein besserer Ansatz und kann die Leistung verbessern.
Das obige ist der detaillierte Inhalt vonHibernate MultipleBagFetchException: Wie lassen sich Eager-Fetching-Probleme während der SessionFactory-Erstellung lösen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!