hibernate und list - Keine Ordnung möglich

Status
Nicht offen für weitere Antworten.
B

berny76

Gast
Hallo,

ich möchte gerne aus java heraus über hibernate eine collection in eine mysql-db speichern. Dabei soll die Reihenfolge der eingefügten Objekte eingehalten werden. Ich finde keinen Weg. Habe auch schon stundenlang recherchiert und die hibernatedoku gelesen.

Konkret sieht der Fall so aus: Ich habe 2 POJOs Ticket und Category. Jedes Ticket hat eine oder viele Kategorien. Jede Kategorie hat 0 oder viele Tickets. Also eine n:m Beziehung. Die Beziehung habe ich auch schon lauffähig bekommen. Allerdings mit einem Set. Da aber bei einem Set nicht die Einfügereihenfolge berücksicht wird, möchte ich auf eine list wechseln; bekomme das Mapping aber nicht realisiert.

Der alte code mit einem Set:

Code:
package ticketkasse.model;

import java.util.HashSet;
import java.util.Set;


public class Ticket {
    private int id;
    private String name;
    ...
    private Set<Category> categories = new HashSet<Category>();

    public int getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Set<Category> getCategories() {
        return categories;
    }

    public void setCategories(Set<Category> category) {
        this.categories = category;
    }

}




package ticketkasse.model;

import java.util.HashSet;
import java.util.Set;

public class Category {
   private int id;
   private String name;
   private Set<Ticket> tickets = new HashSet<Ticket>();

    public int getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Set<Ticket> getTickets() {
        return tickets;
    }

    public void setTickets(Set<Ticket> tickets) {
        this.tickets = tickets;
    }   
   
}


Die hbm.xml files dazu:

Code:
<hibernate-mapping>
  <class name="ticketkasse.model.Ticket" table="TICKET">
    <id name="id" column="ID" type="integer">
      <generator class="native"/>
    </id>
    <property name="name"  column="NAME"  type="java.lang.String" not-null="true"/>
       ...
    <set name="categories" table="TICKET_CATEGORY" lazy="false">
      <key column="ID_TICKET"/>
      <many-to-many class="ticketkasse.model.Category" column="ID_CATEGORY"/>
    </set>
  </class>
</hibernate-mapping>



<hibernate-mapping>
  <class name="ticketkasse.model.Category" table="CATEGORY">
    <id name="id" column="ID" type="integer">
      <generator class="native"/>
    </id>
    <property name="name"  column="NAME"  type="java.lang.String" not-null="true" />
    <set name="tickets" table="TICKET_CATEGORY" lazy="false">
      <key column="ID_CATEGORY"/>
      <many-to-many class="ticketkasse.model.Ticket" column="ID_TICKET"/>
    </set>
  </class>
</hibernate-mapping>

Wäre schön, wenn mir dabei einer helfen könnte.
 

ms

Top Contributor
Wie wäre es wenn du auf die Einfügereihenfolge pfeifst und einfach beim Selektieren ein ORDER BY machst?

ms
 
B

berny76

Gast
Verstehe ich nicht. Wie sollte mir ein ORDER BY helfen? Welches Kriterium würde ich angeben, an dem geordnet werden kann?
 
G

Guest

Gast
berny76 hat gesagt.:
Verstehe ich nicht. Wie sollte mir ein ORDER BY helfen? Welches Kriterium würde ich angeben, an dem geordnet werden kann?
Nach Kategorie und Ticket-Id sortiert. Neuere Einträge haben ja eine höhere Id.
 
B

berny76

Gast
Aha ok, und wo kann ich das angeben? Kann man das im mapping file mit reinschreiben? Ein richtgiger von mir gemachter Select findet ja nicht statt. Das übernimmt ja intern das Framework. In Java selbst habe ich ja nur die POJOs.

Ein anderer Weg wäre ja ein list-element statt eines set-elements im mapping file einzutragen und dann list-index irgendwie mit dem index der java-list zu kombinieren. Das, denke ich, wäre eine saubere Lösung, bloß bekomme ich das nicht gebacken. :cry:
 
G

Guest

Gast
berny76 hat gesagt.:
Aha ok, und wo kann ich das angeben? Kann man das im mapping file mit reinschreiben? Ein richtgiger von mir gemachter Select findet ja nicht statt. Das übernimmt ja intern das Framework. In Java selbst habe ich ja nur die POJOs.
Mit NamedQueries oder von mir aus mit "normalen" Queries.
So ungefähr
Code:
Query query = em.createQuery(
   "select t"
  +"  from Ticket t"
  +"       join t.categories cat"
  +" where cat.id = :categoryId"
  +" order by t.id"
);
query.setParameter("categoryId", categoryId);
List<Ticket> ticketList = query.getResultList();
 
G

Guest

Gast
Versuche auch das hier
Code:
<hibernate-mapping>
  <class name="ticketkasse.model.Category" table="CATEGORY">
    <id name="id" column="ID" type="integer">
      <generator class="native"/>
    </id>
    <property name="name"  column="NAME"  type="java.lang.String" not-null="true" />
    <set name="tickets" table="TICKET_CATEGORY" lazy="false" order-by="ID_TICKET asc">
      <key column="ID_CATEGORY"/>
      <many-to-many class="ticketkasse.model.Ticket" column="ID_TICKET"/>
    </set>
  </class>
</hibernate-mapping>

oder

public class Category {
   private int id;
   private String name;
   private SortedSet<Ticket> tickets = new TreeSet<Ticket>();
   ...
}

public final class TicketComparator implements Comparator<Ticket>
{
   public TicketComparator()
   {
   }

   public int compare(Ticket t1, Ticket t2)
   {
      return t1.getId() - t2.getId();
   }
}

<hibernate-mapping>
  <class name="ticketkasse.model.Category" table="CATEGORY">
    <id name="id" column="ID" type="integer">
      <generator class="native"/>
    </id>
    <property name="name"  column="NAME"  type="java.lang.String" not-null="true" />
    <set name="tickets" table="TICKET_CATEGORY" lazy="false" sort="ticketkasse.model.TicketComparator">
      <key column="ID_CATEGORY"/>
      <many-to-many class="ticketkasse.model.Ticket" column="ID_TICKET"/>
    </set>
  </class>
</hibernate-mapping>
 
B

berny76

Gast
Anonymous hat gesagt.:
berny76 hat gesagt.:
Verstehe ich nicht. Wie sollte mir ein ORDER BY helfen? Welches Kriterium würde ich angeben, an dem geordnet werden kann?
Nach Kategorie und Ticket-Id sortiert. Neuere Einträge haben ja eine höhere Id.
Geht meiner Ansicht nach nicht. Neue Einträge haben in meinem Fall keine höhere id, weil es in der Beziehungstabelle keine id-spalte gibt. Die Beziehungstabelle enthält nur die beiden Fremdschlüssel von Ticket und Category. Somit hilft mir dein Ansatz leider nicht weiter.

Ich habe es jetzt mit einem idbag ich denke sauber gelöst.

Die POJOs enthalten jetzt keine Sets mehr, sondern wie gewollt jeweils eine List. Die mapping files haben sich wie folgt verändert:

Code:
<hibernate-mapping>
  <class name="ticketkasse.model.Ticket" table="TICKET">
    <id name="id" column="ID" type="integer">
      <generator class="native"/>
    </id>
    <property name="name"  column="NAME"  type="java.lang.String" not-null="true"/>
       ...
    <idbag name="categories" table="TICKET_CATEGORY" lazy="false">
        <collection-id column="ID" type="long">
            <generator class="increment"/>
        </collection-id>        
      <key column="ID_TICKET"/>   
      <many-to-many class="ticketkasse.model.Category" column="ID_CATEGORY"/>
    </idbag>
  </class>
</hibernate-mapping>



<hibernate-mapping>
  <class name="ticketkasse.model.Category" table="CATEGORY">
    <id name="id" column="ID" type="integer">
      <generator class="native"/>
    </id>
    <property name="name"  column="NAME"  type="java.lang.String" not-null="true" />
    <idbag name="tickets" table="TICKET_CATEGORY" lazy="false">
        <collection-id column="ID" type="long">
            <generator class="increment"/>
        </collection-id>
      <key column="ID_CATEGORY"/>
      <many-to-many class="ticketkasse.model.Ticket" column="ID_TICKET"/>
    </idbag>
  </class>
</hibernate-mapping>

Es gab nur anfangs ein Problem mit dem collection-id-generator. Laut hibernate-doku soll man "sequence" nehmen. Da bekam ich aber Ärger mit meinem verwendeten SQL-Dialect für MySql. Ein wenig googeln und ausprobieren ergab dann "increment" als verständlich und brauchbar.

Dennoch danke fürs Finden einer Lösung. :)
 
O

ollix

Gast
Hi Berny,

thanks a lot for this excellent thread. I guess it saved me a lot of precious time. It is an absolute mistery to me, why a list cannot be mapped in a many-to-many relation. Only the gods of hibernate might have a clue about this.
Thanks again!
:eek:llix
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Hibernate/Spring JPA: eigene ID generieren Data Tier 5
Avalon @ManyToOne Hibernate oder JPA? Data Tier 5
D Hibernate Hibernate mit MariaDB Data Tier 1
ToBJo Hibernate Glassfish deploy mit Hibernate schlägt fehl Data Tier 1
C JPA Hibernate Map<String,String> richtig mappen Data Tier 2
S JPA Hibernate Search & EclipseLink (oder OpenJPA) Data Tier 0
R JPA Probleme mit Wechsel von EclipseLink auf Hibernate Data Tier 4
ARadauer Hibernate Entität readonly laden... Data Tier 1
G Hibernate SQL in Hibernate: Keine Parameter mit Index? Data Tier 2
P Wildfly + Hibernate + SQL Server Data Tier 0
E JPA Hibernate Query mit Timestamp hat seltsames Verhalten Data Tier 1
M Eclipse 4 RCP Hibernate Problem Data Tier 3
C Hibernate ProgressBar updaten mit Daten aus Hibernate Data Tier 4
B Hibernate und MySQL testen Data Tier 8
I Hibernate HQL: generiertes SQL ausgeben Data Tier 1
R mapping-file für hibernate zum Überschreiben der Annotationen Data Tier 7
R Hibernate Hibernate und Logback Data Tier 2
R Hibernate möchte Schema zwei mal undeployen Data Tier 2
F Hibernate Hibernate / JPA Data Tier 4
E Hibernate: Session vs EntityManager Data Tier 3
C Hibernate Hibernate Code Generation Data Tier 3
S Hibernate Mehrfachverbindung mit Hibernate Data Tier 3
M Hibernate Einstiegsfrage Data Tier 5
M Exception in thread "main" org.hibernate.MappingException: java.lang.ClassNotFoundException: Message Data Tier 4
S Hibernate Einstieg in Hibernate 3.2 sinnvoll? Data Tier 8
P JPA Eigene Vererbungsstrategie mit JPA / Hibernate Data Tier 2
J Hibernate Problem bei Master-Detail-Tabellen Data Tier 5
Y Jboss seam-hibernate-jpa Data Tier 5
RaoulDuke Hibernate Map<String,String> mit Annotations mappen Data Tier 2
M Hibernate Hibernate with GWT Data Tier 4
C Hibernate JPA mysql db erstellen Data Tier 4
M Hibernate Hibernate liest Daten zu oft aus! Data Tier 16
pg1337 Hibernate Fragen Data Tier 11
D Probleme bei Left Joins mit Hibernate createCriterias() Data Tier 2
D Hibernate probleme mit Verlinkungstabelle Data Tier 4
2 Hibernate Annotations Data Tier 7
G Hibernate select update no wait Data Tier 8
Z Hibernate: Many-To-Many nur eine bestimmte Spalte Data Tier 3
K Hibernate - Envers - Erzeugung der SQL Skripte Data Tier 4
G Hibernate 1:n Beziehung mit Vererbung Data Tier 5
D Hibernate-Criteria-API (Projections und MAX-Funktion) Data Tier 6
L Hibernate: failed to lazily initialize a collection of role Data Tier 3
S Hibernate hibernate.cfg.xml Data Tier 14
D JPA vs Hibernate.cfg und Entitymanager Data Tier 6
H Hibernate - Mapping für Enumeration Data Tier 1
R Hibernate Criteria Abfrageproblem Data Tier 2
A Hibernate und jdbc zusammen Data Tier 4
D Mit Hibernate aus JUnit ein DB-Schema erzeugen Data Tier 6
S [Hibernate] No Persistence provider for EntityManager Data Tier 5
B Problem mit org.hibernate.LazyInitializationException Data Tier 11
G Hibernate HQL und Interface Data Tier 4
G JSF Hibernate no session or session was closed Data Tier 12
T JPA2/Hibernate: Many-to-Many-Relation wird u.a. beim löschen nicht aktualisiert Data Tier 14
S (Hibernate) Mapping einer Datenbanktabelle mit mehreren Fremdschlüssel Data Tier 7
X [Hibernate] Zusammengesetzte Entities möglich? Data Tier 7
N Hibernate Fake? Data Tier 2
S Problem beim Insert mit Hibernate Data Tier 9
V Hibernate Projection Data Tier 2
T org.hibernate.impl.SessionFactoryImpl Memory Leak Data Tier 10
G Hibernate Composite key Data Tier 11
X [Hibernate] Connection Pool - MinSize ? Data Tier 2
R Hibernate Criteria OR Data Tier 2
T hibernate/jpa abgefragte Listen immer mit Null-Werten gefüllt Data Tier 8
X [Hibernate] Anderen Connection Pool - Vorschläge? Data Tier 3
ARadauer Hibernate DDL Loggen Data Tier 6
G Hibernate abfrage Collection Data Tier 3
X [Hibernate] ReverseEngineering - Eigene Strategy verwenden? Data Tier 3
R Hibernate Criteria .group größer als Data Tier 5
R Hibernate daten laden Data Tier 7
H [Hibernate]1:1 Beziehung Data Tier 8
H [Hibernate]No CurrentSessionContext configured! Data Tier 6
X [Hibernate] Lässt sich die Dauer eines SELECTs loggen? Data Tier 4
R Hibernate n:n Relationtabelle mit Date Data Tier 3
H [Hibernate] Unknown Entity Data Tier 3
H [Hibernate] Configuration Data Tier 3
C [Hibernate] Generierung von hbm.xml to Java Data Tier 4
lumo Eclipse & JPA & Hibernate & Derby Data Tier 5
J Zufallsauswahl aus ResultList bei JPA(Hibernate) / Performance Data Tier 3
M Hibernate: Datum 0001-01-01 erzeugt null-Datum Data Tier 4
G Datenbankzugriff mit Hibernate Data Tier 7
Y Hibernate - Angabe des Schemas Data Tier 6
LadyMilka (Hibernate) in Criteria implizierter Join durch Subquery's Data Tier 8
M Hibernate Mehr als 1 Object speichern? Data Tier 18
M Unerklärliche Hibernate Exception Data Tier 20
LadyMilka (Hibernate) subquery in FROM-Clause Data Tier 9
haemi Viele DTOs in hibernate IdentityMap Data Tier 3
LadyMilka (hibernate) UNION dem Dialekt hinzufügen Data Tier 3
M Hibernate + Oracle 10g XE Data Tier 3
lumo Hibernate - entity class not found Data Tier 5
P SQL PRoblem Hibernate? Data Tier 8
J Vererbung mit JPA / Hibernate - pro/contra Data Tier 3
T JBoss/Hibernate: Abfrage dauert lang + hohe CPU? Data Tier 19
7 Hibernate-Abfrage (SubSelect im FROM) Data Tier 2
G Hibernate: many-to-one - Verwaiste Datensätze löschen Data Tier 2
G Layer für Datenbankzugriff Hibernate Data Tier 5
G Hibernate Zwischentabelle Data Tier 2
Java.getSkill() Hibernate und Spalte vom Typ xml Data Tier 6
G Hibernate 0...1 : 1 Beziehung Data Tier 6
G Hibernate mehrere @oneToone Data Tier 2
G Hibernate 1:n, 1:1 Data Tier 26

Ähnliche Java Themen

Neue Themen


Oben