ich eine Klasse sagen: "Klasse A", die eine Sammlung von "ClassB" hatHibernate @OrderBy mit referenzierten Klasse
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
@JoinColumn(name = "COLUMN_NAME")
private List<ClassB> lotsOfClasses;
"ClassB" hat ein zugeordnetes Klasse "ClassC" Anmerkungen plain old Mapping:
public class ClassB {
...
@ManyToOne
@JoinColumn(name="AD_POINT_ID")
private ClassC classC;
...
}
Wie kann ich eine @OrderBy Anmerkung zu KlasseA Sammlung zu ClassB hinzufügen, so dass die Sammlung der „Name“ Eigenschaft ClassC bestellt
Wie so:
Alles, was ich bekomme, sind Oracle Ausnahmen, die sagen, dass classC ist unbekannt.
Jede Hilfe hier wäre toll, da es mich im Moment wirklich nervt.
P.S. Ich sollte auch erwähnen, dass die Verwendung der OrderBy Annotation auf der Sammlung wie folgt: @OrderBy (clause = "classC asc") (dh ohne die. Name auf Klasse C) Ich bekomme eine gültige SQL-Anweisung, die die ID-Spalte verwendet Primärschlüssel) von classC zur Bestellung von.
Cheers, Mark
Wie von Jiří Vypědřík vorgeschlagen, dass Sie java.util.Comparator Schnittstelle implementieren können. In der implementierten Vergleichsmethode können Sie die Logik implementieren, um problemlos auf das Hibernate Mapped-Objekt zu verweisen, und den int-Wert entsprechend zurückgeben. Dies verwendet jedoch nicht die Sortierung auf der Oracle-Datenbank, sondern die In-Memory-Sortierung (JVM). – prageeth