MySQL Hibernate (duplicate Entry) Beziehungstabelle wird nicht befüllt

BoggyB

Mitglied
Hallo zusammen,

da ich jetzt schon länger suche und noch immer keine Lösung für mein Problem gefunden habe versuche ich es einfach mal hier.

Zur Problemstellung (vereinfacht):

Ich habe ein XML-File mit Nachrichten bestehend aus Headline, Datum und Anbieter.
Eine Nachricht kann mehrere Anbieter haben.
Ein Anbieter wiederum kann mehreren Nachrichten zugeordnet werden.
Meine Aufgabe ist es die Daten vom XML-File in die Datenbank zu buchen.

Einfügen in die Tabellen funktioniert. Die Beziehungstabelle wird auch befüllt. Das Problem bei der ganzen sache ist nur, dass die Beziehungstabelle nicht befüllt wird, wenn der Anbieter bereits in der Datenbank existiert. Vermutlich weil kein Autoincrement der id erfolgt und diese somit auch nicht zurückgeliefert wird.
Kann ich Hibernate irgendwie sagen, dass er sich die id eines Anbieters holen soll falls der Insert wegen eines Duplicate Entrys nicht ausgeführt werden kann und dann die Beziehungstabelle mit diesem Wert befüllt?

Ich bedanke mich schon mal für alle eventuellen Antworten.
Buchempfehlungen und Blogeinträge zu dem Thema sind natürlich herzlich willkommen.

LG

Fabian

Die Tabellen in Mysql sind folgendermaßen aufgebaut:

Tabelle: news
Spalte: id (Primärschlüssel)
Spalte: headline
Spalte: datum

Tabelle: news_anbieter (Verbindungstabelle)
Spalte: n_id (ID aus Tabelle news)
Spalte: a_id (ID aus Tabelle anbieter)

Tabelle: anbieter
Spalte: id (Primärschlüssel)
Spalte: name (Unique)

Ich hab mir nach dem Vorbild die Mapping files zusammengebaut:
Objektrelationales Mapping (O/R-M) mit Hibernate

[XML]<hibernate-mapping>
<class name="nachrichten.entity.News" table="news" catalog="portal_nachrichten_fa">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="identity" />
</id>
<property name="headline" type="string">
<column name="headline" length="200" not-null="true" />
</property>
<property name="date" type="timestamp">
<column name="date" length="19" />
</property>
<set name="anbieter" table="news_anbieter" lazy="true">
<key column="N_ID"/>
<many-to-many class="nachrichten.entity.Anbieter" column="A_ID"/>
</set>
</class>
</hibernate-mapping>[/XML]

[XML]hibernate-mapping>
<class name="nachrichten.entity.Anbieter" table="anbieter" catalog="portal_nachrichten_fa">
<id name="id" type="java.lang.Integer">
<column name="id" />
<generator class="identity" />
</id>
<property name="name" type="string">
<column name="name" length="50" unique="true" />
</property>
<set name="news" table="news_anbieter" lazy="true">
<key column="A_ID"/>
<many-to-many class="nachrichten.entity.News" column="N_ID"/>
</set>
</class>
</hibernate-mapping>[/XML]

POJOs

Java:
public class Anbieter implements java.io.Serializable
{

    private Integer id;
    private String name;
    private Set news = new HashSet();

    public Anbieter()
    {
    }

    public Anbieter(String name)
    {
        this.name = name;
    }

    public Integer getId()
    {
        return this.id;
    }

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

    public String getName()
    {
        return this.name;
    }

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

    public Set getNews()
    {
        return this.news;
    }

    public void setNews(Set news)
    {
        this.news = news;
    }
}

Java:
public class News implements java.io.Serializable
{

    private Integer id;
    private String headline;
    private Date date;
    private Set anbieter = new HashSet();

    public News()
    {
    }

    public News(String headline)
    {
        this.headline = headline;
    }

    public News(String headline, Date date)
    {
        this.headline = headline;
        this.date = date;
    }

    public Integer getId()
    {
        return this.id;
    }

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

    public String getHeadline()
    {
        return this.headline;
    }

    public void setHeadline(String headline)
    {
        this.headline = headline;
    }

    public Date getDate()
    {
        return this.date;
    }

    public void setDate(Date date)
    {
        this.date = date;
    }

    public Set getAnbieter()
    {
        return this.anbieter;
    }

    public void setAnbieter(Set anbieter)
    {
        this.anbieter = anbieter;
    }
}

Code zum Einfügen

Java:
 public static void insert()
    {
        Session sess = null;
        try
        {
            sess = HibernateUtil.getSessionFactory().openSession();;
            Transaction tx = sess.beginTransaction();
            
            News news = new News();
            news.setHeadline("Zufallszahl: " + Math.random() * 50);
            news.setDate(new Date()); 
            
            Anbieter anbieter1 = new Anbieter("anbieter1");  
            anbieter1.getNews().add(news); 
            news.getAnbieter().add(anbieter1);
            
            sess.saveOrUpdate(news);
            sess.saveOrUpdate(anbieter1);

            tx.commit();
        }
        catch (Exception e)
        {
            System.out.println(e.getMessage());
        }
        finally
        {
            sess.close();
        }
    }



Ich benutze NetBeans 7.0 auf einem Windows XP Rechner.
 

gafktor

Mitglied
Hallo BoggyB,

du hast recht es liegt daran, das Hibernate den Anbieter nicht kennt und von daher auch keinen Primarykey hat, der in die Beziehungstabelle eingetragen werden könnte. Eine Einstellung das Hibernate sich das automatisch aus der Tabelle sucht gibt es meines Wissens nicht. Dürfte auch kaum gehen. Woher soll denn die Info kommen welcher Datensatz gemeint ist.

Du hast in der Anbietertabelle name auf unique gesetzt. Dadurch wird der Anbieter beim erneuten Aufruf nicht in die table eingefügt. -> Folge kein PK im Objekt Anbieter -> keine Fortschreibung der Verbindungstabelle.

Zur Lösung mußt du die DB abfragen, ob der Anbieter vorhanden ist. Wenn ja, setzt du ihn auf das gefundene Entity ansonsten neu anlegen.

Ich habe damals das Buch "Java-Persistence-Api mit Hibernate" als hilfreich empfunden. Aber das ist ja immer ein wenig Geschmackssache.

Du solltest dir vielleicht überlegen von xml-Mapping auf Annotationen zu wechseln.
 

BoggyB

Mitglied
Danke dir gafkor,

dann weiß ich schon mal dass ich in die richtung nichts mehr suchen muss.
Warum Annotations? Ich bin relativ neu in der Materie, deswegen kenn ich mich noch nicht so gut aus.
 

BoggyB

Mitglied
Dankeschön,

ich habe eine vorläufige Lösung gefunden.
Ich speichere den Anbieter nur ab wenn er in der DB noch nicht existiert.
Ansonsten hol ich mir die id des Anbieters und füge sie dem Anbieterobjekt manuell hinzu.
=> Die Beziehungstabelle wird befüllt.

Code folgt.
 

BoggyB

Mitglied
Ich habe es jetzt doch auf Annotations umgestellt, ist tatsächlich schöner, weniger klassen weniger code. Funktioniert auch soweit wenn ich 2 nachrichten mit dem gleichen anbieter befülle (in einer session). Wenn ich aber das programm nochmal ausführe und ich versuche den gleichen anbieter nochmal einzufügen funktioniert es nicht.

@maki
Du meintest Stichpunkt Cascade, ich habe einige ausprobiert (@ManyToMany(cascade = CascadeType.ALL .MERGE .PERSIST) aber habe nie das gewünschte Ergebnis erhalten.
Hast du noch einen tipp für mich? Sonst muss ich halt manuell prüfen.
 
M

maki

Gast
Hi,

sorry, mein "Tipp" mit dem cascade war falsch, deine Lösung ist schon richtig, JPA managed einem nicht magisch die Beziehungen, muss man selber machen.

Wenn du noch Fehler hast wäre ien Stacktrace & eine Fehlerbeschriebung nützlich.
 

BoggyB

Mitglied
Ich hab jetzt eine Lösung mit Annotations die funktioniert.
Ich poste die mal hier für alle die das gleiche Problem haben.

Anbieter
Java:
package portal_nachrichten.entity;
// Generated 03.11.2011 16:07:18 by Hibernate Tools 3.2.1.GA

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import static javax.persistence.GenerationType.IDENTITY;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.persistence.UniqueConstraint;

/**
 * Anbieter generated by hbm2java
 */
@Entity
@Table(name = "anbieter", catalog = "db_nachrichten", uniqueConstraints =
@UniqueConstraint(columnNames = "name"))
public class Anbieter implements java.io.Serializable
{

    private Integer id;
    private String name;

    public Anbieter()
    {
    }

    public Anbieter(String name)
    {
        this.name = name;
    }

    @Id
    @GeneratedValue(strategy = IDENTITY)
    @Column(name = "id", unique = true, nullable = false)
    public Integer getId()
    {
        return this.id;
    }

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

    @Column(name = "name", unique = true, length = 50)
    public String getName()
    {
        return this.name;
    }

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

Nachricht
Java:
package portal_nachrichten.entity;
// Generated 07.11.2011 14:02:06 by Hibernate Tools 3.2.1.GA

import java.util.Date;
import java.util.HashSet;
import java.util.Set;
import javax.persistence.*;
import static javax.persistence.GenerationType.IDENTITY;

/**
 * News generated by hbm2java
 */
@Entity
@Table(name = "news", catalog = "db_nachrichten", uniqueConstraints =
@UniqueConstraint(columnNames =
{
    "headline", "date"
}))
public class News implements java.io.Serializable
{

    private Integer id;
    private String headline;
    private Date date;
    private Set<Anbieter> anbieter = new HashSet<Anbieter>();

    public News()
    {
    }

    public News(String headline)
    {
        this.headline = headline;
    }

    public News(String headline, Date date)
    {
        this.headline = headline;
        this.date = date;
    }

    @Id
    @GeneratedValue(strategy = IDENTITY)
    @Column(name = "id", unique = true, nullable = false)
    public Integer getId()
    {
        return this.id;
    }

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

    @ManyToMany(cascade = CascadeType.MERGE)
    @JoinTable(name = "news_anbieter", joinColumns =
    {
        @JoinColumn(name = "n_id")
    }, inverseJoinColumns =
    {
        @JoinColumn(name = "a_id")
    })
    public Set<Anbieter> getAnbieter()
    {
        return anbieter;
    }

    public void setAnbieter(Set<Anbieter> anbieter)
    {
        this.anbieter = anbieter;
    }

    @Column(name = "headline", nullable = false, length = 200)
    public String getHeadline()
    {
        return this.headline;
    }

    public void setHeadline(String headline)
    {
        this.headline = headline;
    }

    @Temporal(TemporalType.TIMESTAMP)
    @Column(name = "date", length = 19)
    public Date getDate()
    {
        return this.date;
    }

    public void setDate(Date date)
    {
        this.date = date;
    }
}

Bevor ich versuche in die Datenbank einzufügen hole ich mittels einer HQL Abfrage die id eines Anbieters falls dieser in der DB bereits existiert und füge sie zu dem jeweiligen Anbieter-Objekt hinzu.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
torresbig MySQL hibernate - could not resolve entity class ... (Datenbank Anfänger) Datenbankprogrammierung 19
I Hibernate Predicate mit IN Clause "Unaware how to convert value to requested type" Datenbankprogrammierung 0
T org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role: ..., could not initialize proxy - no Session Datenbankprogrammierung 5
T Realisierungsvorschläge Hibernate SQL Datenbankprogrammierung 1
Zrebna Wie mittels Hibernate eine Join-Tabelle als eigene Java-Klasse erstellen? Datenbankprogrammierung 5
Zrebna Tabellen-Erzeugung via Hibernate ignoriert 'CascadeType' settings Datenbankprogrammierung 1
I Hibernate / JPA - Spaltenname von Query (Select) bekommen Datenbankprogrammierung 6
M Mysql Views und Hibernate Caching Datenbankprogrammierung 4
damike84 Hibernate: persistieren eines Graphen Datenbankprogrammierung 2
N Hibernate Entitäten bei Selects aus 2 Tabellen Datenbankprogrammierung 7
OnDemand Hibernate Realationen Datenbankprogrammierung 7
OnDemand Hibernate ManyToOne Datenbankprogrammierung 5
D Hibernate oneToMany Syntaxfehler Datenbankprogrammierung 3
D Hibernate Error: NoSuchMethodError Datenbankprogrammierung 4
D hibernate mit postgreSQL Datenbankprogrammierung 3
S MySQL Hibernate: Fehler bei Verwendung von 2 unterschiedlichen Enumration Datenbankprogrammierung 3
F Problem mit Hibernate c3p0 Datenbankprogrammierung 2
OnDemand MySQL Trigger löst nicht aus bei Hibernate Update Datenbankprogrammierung 12
OnDemand Hibernate OneToMany ManyToOne Datenbankprogrammierung 61
J Hibernate One-To-One mit Where Klausel Datenbankprogrammierung 6
L hibernate.cfg.xml Could not parse configuration Datenbankprogrammierung 0
L H2 Hibernate definieren? Datenbankprogrammierung 1
T JPA Mapping Enum (hibernate 5) Datenbankprogrammierung 1
H In hibernate.cfg.xml schreiben und auslesen Datenbankprogrammierung 0
K Hibernate: Ein Fluch Datenbankprogrammierung 3
K Java Object mit Hibernate in MySQL abspeichern Datenbankprogrammierung 1
K Eclipse: JBoss Hibernate Tool: Kein Zugriff auf Datenbank Datenbankprogrammierung 5
S JpaRepositories & Hibernate: ungewolltes trim() in findBy Datenbankprogrammierung 7
S MySQL hibernate exception: illegal state exception : entityManagerFactory is closed Datenbankprogrammierung 5
S Hibernate: Verschiedene Klassen zurückgeben. Datenbankprogrammierung 2
looparda Architektur für JPA Hibernate Umstieg Datenbankprogrammierung 14
O HSQLDB Hibernate Criteria Problem Datenbankprogrammierung 3
perlenfischer1984 Hibernate mit final members Datenbankprogrammierung 3
perlenfischer1984 Java Objecte speichern mit Hibernate ? Datenbankprogrammierung 2
N SQLite Hibernate und Aufruf von Funktion SELECT last_insert_rowid() Datenbankprogrammierung 2
N Sqlite3 und Hibernate Datenbankprogrammierung 3
A Hibernate Cache leeren Datenbankprogrammierung 4
I MySQL Hibernate zu viele Queries Datenbankprogrammierung 2
Psypsy Hibernate / JPA erkennen von schon gespeicherten Objekten Datenbankprogrammierung 4
Psypsy Hibernate / JPA OneToOne MappedBy Frage Datenbankprogrammierung 2
J Hibernate + DTOs - DTOs in DAOs verwenden? Datenbankprogrammierung 1
S Hibernate-Konfiguration : Unverständliche Ausgabe beim Ausführen Datenbankprogrammierung 0
I MySQL Hibernate / MySQL alias in WHERE clause Datenbankprogrammierung 1
J Hibernate + HSQL embedded Datenbankprogrammierung 2
P Hibernate Einstieg Datenbankprogrammierung 5
C Hibernate und createQuery Datenbankprogrammierung 2
V kennt jemand empfehlenswerte online tutorials zur Hibernate ? gerne auch englisch. Datenbankprogrammierung 4
G H2 Hibernate - wie joins machen Datenbankprogrammierung 1
D Hibernate: Zustand eines Objekts erkennen? Datenbankprogrammierung 0
D Unterschiede Hibernate Vs. Java Persistence API Datenbankprogrammierung 8
I Hibernate / JPA Index hinzufügen Datenbankprogrammierung 1
X Hibernate Cache Verständnisproblem Datenbankprogrammierung 0
T Hibernate und inner class Datenbankprogrammierung 0
K n:m Tabellen mit Hibernate erstellen Datenbankprogrammierung 1
T Hibernate DAO gute Tutorials/Bücher gesucht Datenbankprogrammierung 0
C Hibernate: could not resolve property Datenbankprogrammierung 1
J Plug-In-Framework für Hibernate-Klassen Datenbankprogrammierung 0
M Hibernate - Save Child wenn nötig Datenbankprogrammierung 10
M DAO's + Hibernate Theorie Datenbankprogrammierung 4
T Hibernate, HSQLDB und UNIQUE Datenbankprogrammierung 2
F Hibernate - verschiedene Schemen Datenbankprogrammierung 7
D Hibernate SaveOrUpdate Exception Datenbankprogrammierung 2
D Hibernate CreateQuery ohne Result Datenbankprogrammierung 7
E MySQL Hibernate mit JaxWS führt zu LazyInitialization Exception Datenbankprogrammierung 8
L Einarbeitung in Hibernate -> wenn gute SQL Kenntnisse vorhanden? Datenbankprogrammierung 2
B DB2 Hibernate findet Datenbank nicht Datenbankprogrammierung 18
K JPA / Hibernate Annotations Datenbankprogrammierung 4
M JPA / Hibernate mit Postgres DB Datenbankprogrammierung 3
P JSF + H2 + TomEE + Hibernate/JPA Datenbank wird nicht angelegt Datenbankprogrammierung 3
E MySQL Hibernate ( Anfänger ) Datenbankprogrammierung 3
P Lazy-Fetchig und Session-Problem mit Hibernate Datenbankprogrammierung 4
J Hibernate Select auf Parameterliste Datenbankprogrammierung 3
C Hibernate ManyToMany zusammengesetzter Primärschlüssel, problem. Datenbankprogrammierung 3
P Oracle Hibernate - Oracle-VarChar-Index wird nicht genutzt Datenbankprogrammierung 3
M Hibernate Foreign Key definieren Datenbankprogrammierung 4
M Abstrakte Klassen Hibernate Datenbankprogrammierung 4
D Mit Hibernate (mit Annotation) auf Views zugreifen Datenbankprogrammierung 2
M [Hibernate]Abgleich eines lokalen Objekts mit dem Zustand aus der Datenbank. Datenbankprogrammierung 3
P Mit Hibernate mehrere Datensätze löschen Datenbankprogrammierung 7
P Probleme mit meinem 1. Hibernate Beispiel Datenbankprogrammierung 3
P erste Schritte mit Hibernate Datenbankprogrammierung 3
V Hibernate Interfaces von anderem Projekt Datenbankprogrammierung 2
J MySQL Datenbank konfigurieren, JDBC, MySQL oder Hibernate Datenbankprogrammierung 2
B Hibernate und portierbare Datenbank Datenbankprogrammierung 3
qwerqer [Hibernate] Mappingvarianten Datenbankprogrammierung 2
lumo Teneo Hibernate & JPA Datenbankprogrammierung 15
Z JPA mit Hibernate - Unable to build EntityManagerFactory Datenbankprogrammierung 7
Dit_ Hibernate, effiziente SQL-Abfrage definieren Datenbankprogrammierung 5
K Hibernate vs. JDBC Datenbankprogrammierung 4
J Hibernate Info 593 ? Datenbankprogrammierung 4
J Erstellen der SessionFactory in Hibernate 4.1 Datenbankprogrammierung 2
L PostgreSQL Hibernate-Frage Datenbankprogrammierung 2
X MySQL Hibernate: Massenupdate auf unbekannte Tabelle Datenbankprogrammierung 4
N hibernate: datasource Datenbankprogrammierung 7
H MySQL Hibernate: Updaten vereinfachen Datenbankprogrammierung 2
T Hibernate Division zweier Summen Datenbankprogrammierung 4
B MySQL Fehler: Cannot open connection mit Tomcat7, Hibernate und MySQL Datenbankprogrammierung 4
F GWT und Hibernate - gwt.dev.Compler not found Datenbankprogrammierung 3
M NestedTransaction- Exception in Hibernate Datenbankprogrammierung 15
O Löschen vieler Datensätze mit Hibernate Datenbankprogrammierung 11

Ähnliche Java Themen

Neue Themen


Oben