Spring Data: Multiple representations of the same entity

lam_tr

Top Contributor
Hallo zusammen,

ich bin dabei ein eigenes Ticket System zu schreiben und habe bei Modellierung der Anwendung habe ein Problem, vermutlich habe ich etwas falsch parametrisiert. Ich zeige euch schon mal meine Klassen:

Code:
@Entity
public class JiraTicket {

     @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "TICKET_ID", columnDefinition = "BIGINT")
    private long id;

   @ManyToMany(fetch = FetchType.LAZY,
            cascade = {
                CascadeType.PERSIST,
                CascadeType.MERGE
            })
    @JoinTable(name = "TICKET_MEMBERS",
            joinColumns = { @JoinColumn(name = "TICKET_ID") },
            inverseJoinColumns = { @JoinColumn(name = "USER_ID") })
    private Set<User> members = new HashSet<>();
 
    @ManyToMany(fetch = FetchType.LAZY,
            cascade = {
                CascadeType.PERSIST,
                CascadeType.MERGE
            })
    @JoinTable(name = "TICKET_WATCHERS",
            joinColumns = { @JoinColumn(name = "TICKET_ID") },
            inverseJoinColumns = { @JoinColumn(name = "USER_ID") })
    private Set<User> watchers = new HashSet<>();

// Konstruktor, Getter, Setter weggelassen sowie unnötige Felder zur besseren Veranschaulichung
}

Ein Ticket hat in dem Fall eine Reihe von User die das Ticket beobachten und das Ticket hat in dem Fall eine Liste von Teilnehmer. Es ist ähnlich wie bei JIRA modelliert.

Die User Klasse hat an sich keine Besonderheiten, also keine Referenzierungen
Code:
class User{

@Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "USER_ID", nullable = false, columnDefinition = "BIGINT")
    private Long id;

    @Column(nullable = false)
    private String name;

    @Column(nullable = false)
    private String forename;

    @Column(nullable = false)
    private String shortname;
}

Beim Ausführen der Spring Boot Anwendung bekomme ich diese Exception

Code:
Caused by: org.springframework.dao.InvalidDataAccessApiUsageException: Multiple representations of the same entity [de.ticket.system.model.User#39] are being merged. Detached: [de.ticket.system.model.User@2c3c7077]; Detached: [de.ticket.system.model.User@6c842755];

An sich will ich nur eine Fremdtabelle haben die Referenzierungen zwischen Ticket und Users enthalten.

Was mache ich an der Stelle falsch oder unschön?

Ich hoffe das ist verständlich.

Vielen Dank schonmal

lam

Nachtrag: Wenn ich bei members und watchers den CascadeType.Merge entferne, bekomme ich diese Caused by: org.h2.jdbc.JdbcSQLException: Referentielle Integrität verletzt:.

Also allgemein habe ich das noch nicht verstanden.
 
Zuletzt bearbeitet:

lam_tr

Top Contributor
ich habe an der Stelle einfach die Autogenerierung von Eclipse benutzt

Code:
    @Override
   public int hashCode() {
       final int prime = 31;
       int result = 1;
       result = prime * result + ((birthday == null) ? 0 : birthday.hashCode());
       result = prime * result + ((country == null) ? 0 : country.hashCode());
       result = prime * result + ((createdOn == null) ? 0 : createdOn.hashCode());
       result = prime * result + ((email == null) ? 0 : email.hashCode());
       result = prime * result + ((forename == null) ? 0 : forename.hashCode());
       result = prime * result + ((gender == null) ? 0 : gender.hashCode());
       result = prime * result + ((id == null) ? 0 : id.hashCode());
       result = prime * result + ((name == null) ? 0 : name.hashCode());
       result = prime * result + ((shortname == null) ? 0 : shortname.hashCode());
       result = prime * result + status;
       result = prime * result + ((street == null) ? 0 : street.hashCode());
       result = prime * result + ((updatedOn == null) ? 0 : updatedOn.hashCode());
       result = prime * result + ((zip == null) ? 0 : zip.hashCode());
       return result;
   }

   @Override
   public boolean equals(Object obj) {
       if (this == obj)
           return true;
       if (obj == null)
           return false;
       if (getClass() != obj.getClass())
           return false;
       User other = (User) obj;
       if (birthday == null) {
           if (other.birthday != null)
               return false;
       } else if (!birthday.equals(other.birthday))
           return false;
       if (country == null) {
           if (other.country != null)
               return false;
       } else if (!country.equals(other.country))
           return false;
       if (createdOn == null) {
           if (other.createdOn != null)
               return false;
       } else if (!createdOn.equals(other.createdOn))
           return false;
       if (email == null) {
           if (other.email != null)
               return false;
       } else if (!email.equals(other.email))
           return false;
       if (forename == null) {
           if (other.forename != null)
               return false;
       } else if (!forename.equals(other.forename))
           return false;
       if (gender == null) {
           if (other.gender != null)
               return false;
       } else if (!gender.equals(other.gender))
           return false;
       if (id == null) {
           if (other.id != null)
               return false;
       } else if (!id.equals(other.id))
           return false;
       if (name == null) {
           if (other.name != null)
               return false;
       } else if (!name.equals(other.name))
           return false;
       if (shortname == null) {
           if (other.shortname != null)
               return false;
       } else if (!shortname.equals(other.shortname))
           return false;
       if (status != other.status)
           return false;
       if (street == null) {
           if (other.street != null)
               return false;
       } else if (!street.equals(other.street))
           return false;
       if (updatedOn == null) {
           if (other.updatedOn != null)
               return false;
       } else if (!updatedOn.equals(other.updatedOn))
           return false;
       if (zip == null) {
           if (other.zip != null)
               return false;
       } else if (!zip.equals(other.zip))
           return false;
       return true;
   }
 

mihe7

Top Contributor
Das funktioniert nicht. Du musst abprüfen, ob id != null gilt. Falls ja, darf sowohl in equals als auch in hashCode nur die ID eine Rolle spielen.

Hintergrund ist, dass für das HashSet der hashCode() relevant ist, für die DB dagegen die ID. Daher kann Dein HashSet zwei Objekte mit der selben DB-ID enthalten.
 

lam_tr

Top Contributor
meinst du so:
Code:
    @Override
    public int hashCode() {
        if (id!=null) {
            return id.hashCode();
        }
        return super.hashCode();
    }

    @Override
    public boolean equals(Object obj) {
        User other = (User) obj;
        if (id != null) {
            if (other.id != null)
                return id==other.id;
        } 
        return true;
    }
 

mihe7

Top Contributor
Java:
@Override
public boolean equals(Object obj) {
    if (obj == null || obj == this || !(obj instanceof User)) {
        return obj == this;
    }
    User other = (User) obj;
    if (this.id != null) {
        return Objects.equals(this.id, other.id);
    }

    return ...
    // wie auch immer Du Gleichheit zweier Benutzer
    // definierst, falls sie keine ID haben
}

@Override
public int hashCode() {
    if (id != null) {
        return id.hashCode();
    } else {
        // berechne den Hash, so dass
        // er der oben definierten Gleichheit
        // genügt.
    }
}
 

lam_tr

Top Contributor
ok nächstes Exception:)

was bedeutet das denn?

Code:
JdbcSQLException: Referentielle Integrität verletzt: "FK5G3E03L2CXL9GXTOKP0BNJM74: PUBLIC.TICKET_MEMBERS FOREIGN KEY(TICKET_ID) REFERENCES PUBLIC.TICKET(TICKET_ID) (191)"
Referential integrity constraint violation: "FK5G3E03L2CXL9GXTOKP0BNJM74: PUBLIC.TICKET_MEMBERS FOREIGN KEY(TICKET_ID) REFERENCES PUBLIC.TICKET(TICKET_ID) (191)"; SQL statement:

Ich habe in der User Klasse keine Referenzierung auf das Ticket. Ist das eventuell schon das Problem?
 

mihe7

Top Contributor
Hast Du im JiraTicket noch
Java:
@ManyToMany(fetch = FetchType.LAZY,
            cascade = {
                CascadeType.PERSIST,
                CascadeType.MERGE
            })
stehen?

Das sollte eigentlich funktionieren.
 

mihe7

Top Contributor
Sorry, hat ein wenig gedauert, bis ich dazu gekommen bin, den Spaß zu testen: funktioniert unter Payara Micro/JPA einwandfrei.
 

mihe7

Top Contributor
Kannst du mir das freigeben was du getestet hast.
Klar. Ist halt Flickwerk, aber den Zweck erfüllt es :)

Der Connection Pool wird über src/main/webapp/WEB-INF/glassfish-resources.xml konfiguriert. Die Config ist aktuell für MySQL, musst Du für H2 halt entsprechend anpassen, wenn Du es laufen lassen willst.

Bauen und ausführen mit
Code:
mvn package
java -jar payara-micro.jar --deploy target/jpa.war --addJars jdbc-treiber.jar

Es gibt dann einen Satz von REST-Endpoints, die man mit curl ansprechen kann.
Code:
# Ticket inkl. 2 Benutzer (U1, U2) anlegen
# Der Location-Header in der Response liefert die URL
# zum angelegten Ticket
curl -i -XPOST http://localhost:8080/jpa/resources/tickets

# Ticket mit {id} abrufen
curl -i http://localhost:8080/jpa/resources/tickets/{id}

# Alle Tickets abrufen
curl -i http://localhost:8080/jpa/resources/tickets

# Neuen(!) Benutzer mit {name} zum Ticket {id} hinzufügen
curl -i -XPOST http://localhost:8080/jpa/resources/tickets/{id}/{name}

Viel Spaß
 

Anhänge

  • jpa.jar
    5,8 KB · Aufrufe: 3
Ähnliche Java Themen
  Titel Forum Antworten Datum
L Spring Data und Rest Controller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
L Spring Data und Rest Conroller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
L Spring Data: Modellierung mit einer Embeddable bean Frameworks - Spring, Play, Blade, Vaadin & Co 2
L Spring Data: Wie kann ich das Datenmodell richtig definieren? Frameworks - Spring, Play, Blade, Vaadin & Co 6
L Spring Data Einträge von User zahlen und auflisten Frameworks - Spring, Play, Blade, Vaadin & Co 7
S Spring Data Repository delete bulk Frameworks - Spring, Play, Blade, Vaadin & Co 3
R Spring Data: Hibernate liest nicht alle Ebenen Frameworks - Spring, Play, Blade, Vaadin & Co 5
L Spring Data: Detached Entity passed to persist Fehler Frameworks - Spring, Play, Blade, Vaadin & Co 6
S Spring Data data.sql SQL Insert mit single quote Frameworks - Spring, Play, Blade, Vaadin & Co 4
S Spring Data Hibernate mehrfache Suchkriterien Frameworks - Spring, Play, Blade, Vaadin & Co 5
J Spring data JPA Query Frameworks - Spring, Play, Blade, Vaadin & Co 2
G Spring-Boot und Spring Data Programmstart zu langsam Frameworks - Spring, Play, Blade, Vaadin & Co 21
S Spring Data: Lazy Fetch mit Self-Join. Frameworks - Spring, Play, Blade, Vaadin & Co 1
S Spring Data JPA - Repositories werden nicht injected Frameworks - Spring, Play, Blade, Vaadin & Co 2
X spring-data, mongodb und Mapping Frameworks - Spring, Play, Blade, Vaadin & Co 1
D spring data jpa: Wie kann man das Repository Interface in 2 Lese/Schreibe Interfaces aufteilen? Frameworks - Spring, Play, Blade, Vaadin & Co 1
D [InvalidDataAccessApiUsageException] Spring Data JPA / Hibernate Frameworks - Spring, Play, Blade, Vaadin & Co 1
8u3631984 Ist es möglich in Spring Entity generische Listen verwenden Frameworks - Spring, Play, Blade, Vaadin & Co 3
R Spring Boot Test Assertions mit Objekten Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Pfad zu Test Datei in application.yml in Spring Boot Test Frameworks - Spring, Play, Blade, Vaadin & Co 7
R Spring Boot sql Beziehungen Frameworks - Spring, Play, Blade, Vaadin & Co 12
8u3631984 Spring JPA Probleme beim SPeichern von Sets Frameworks - Spring, Play, Blade, Vaadin & Co 3
M Spring Boot 3 Datenbanken zur Laufzeit Verbinden Frameworks - Spring, Play, Blade, Vaadin & Co 5
8u3631984 Spring JDBC Probleme beim Spaltennamen Frameworks - Spring, Play, Blade, Vaadin & Co 3
LimDul Spring-Batches in Docker über Rest starten/verfolgen Frameworks - Spring, Play, Blade, Vaadin & Co 0
ExceptionOfExpectation In Meiner Spring-Boot Applikation verlangt die Datenbank Wert für eine ID Frameworks - Spring, Play, Blade, Vaadin & Co 5
H Spring Boot Applikation und JHM Benchmark sowie ContextConfiguration in H2 Tests ich bekomme es nicht hin Frameworks - Spring, Play, Blade, Vaadin & Co 2
ExceptionOfExpectation Tests in Spring-Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
R Eure Erfahrungen mit Primefaces und Spring - wer managed die Beans Frameworks - Spring, Play, Blade, Vaadin & Co 4
Avalon Get Request doppelt abfeuern ohne Post Redirect Get Pattern. Spring Boot Thymeleaf MVC Frameworks - Spring, Play, Blade, Vaadin & Co 12
thor_norsk Konfigurationsprobleme mit Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 9
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 1
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 13
thor_norsk Spring Boot Fehler Frameworks - Spring, Play, Blade, Vaadin & Co 1
thor_norsk Spring Boot und Docker Frameworks - Spring, Play, Blade, Vaadin & Co 5
B Spring Amazon-SP-Api Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Aktualisiere Spring Controller Frameworks - Spring, Play, Blade, Vaadin & Co 4
D Spring Boot Test ob Validation geprüft wurde Frameworks - Spring, Play, Blade, Vaadin & Co 8
K Spring Boot OneToMany Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Spring Boot Docker Image erstellen und mit docker-compose konfigurieren Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Wann Spring Batch nutzen? Frameworks - Spring, Play, Blade, Vaadin & Co 1
P Spring Hessian Remote Beispiel Frameworks - Spring, Play, Blade, Vaadin & Co 20
8u3631984 Spring 2.7.8 Info Enpoint nicht zuerreichen Frameworks - Spring, Play, Blade, Vaadin & Co 1
gradlew.bat spring-boot:run funktioniert nicht Frameworks - Spring, Play, Blade, Vaadin & Co 4
Zrebna Spring Boot/Thymeleaf: Bestätigungsemail senden. Frameworks - Spring, Play, Blade, Vaadin & Co 2
Zrebna Spring - Thymeleaf: Wieso wird gem. Fallunterscheidung entsprechende View nicht geladen? Frameworks - Spring, Play, Blade, Vaadin & Co 3
Dimax Spring UsernameNotFoundException(msg); auf der View msg ausdrücken Frameworks - Spring, Play, Blade, Vaadin & Co 1
Dimax Spring UsernameNotFoundException(Message) auf der View Message ausdrücken Frameworks - Spring, Play, Blade, Vaadin & Co 2
B Spring Boot und JPA Error creating bean Frameworks - Spring, Play, Blade, Vaadin & Co 24
R Spring Security: Wie kommt 'UserDetails' an Username und Passwort ran? Frameworks - Spring, Play, Blade, Vaadin & Co 6
R Spring Security: Wie den User dynamisch authentifizieren? Frameworks - Spring, Play, Blade, Vaadin & Co 8
R Spring Security: Authentication & Permissions Frameworks - Spring, Play, Blade, Vaadin & Co 4
R Spring Boot: Warum soll PasswordEncoder in einer neuen Methode definiert sein? Frameworks - Spring, Play, Blade, Vaadin & Co 1
8u3631984 Cross-Origin beim Abrufen von Spring Endpoint Frameworks - Spring, Play, Blade, Vaadin & Co 1
D Spring Boot und Microservices Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Boot additional Datasource for a single entity Frameworks - Spring, Play, Blade, Vaadin & Co 0
T Spring Resourcen Ordner ermitteln Frameworks - Spring, Play, Blade, Vaadin & Co 5
B Spring JPA und Repository Frameworks - Spring, Play, Blade, Vaadin & Co 12
D Mapstruct Dependency Injection funktioniert nicht mit Spring Frameworks - Spring, Play, Blade, Vaadin & Co 15
Avalon Wie sieht bei Euch das Deployment einer Spring Boot Anwendung aus? Frameworks - Spring, Play, Blade, Vaadin & Co 4
M Threads in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 7
W DI-Problem in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
T Spring Boot: Was bewirkt parent in maven genau? Frameworks - Spring, Play, Blade, Vaadin & Co 4
T Spring Security: Run-as replacement Einsatzbereich? Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Vaadin+Spring Boot erster Seitenload nach Neustart endlos Frameworks - Spring, Play, Blade, Vaadin & Co 0
doncarlito87 Wie erhalte ich ein JSON aus eine NativeQuery (Spring Boot)? Frameworks - Spring, Play, Blade, Vaadin & Co 8
Avalon @Query Select Abfrage liefert falsche Werte (Spring Boot, JPA, Hibernate) Frameworks - Spring, Play, Blade, Vaadin & Co 3
Avalon Erstellung Dockerimage mit spring-boot:build-image in Spring Boot mit Umgebungsvariablen Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Spring Integration - Logging Frameworks - Spring, Play, Blade, Vaadin & Co 7
D Spring Boot Field Injection in MapStruct Frameworks - Spring, Play, Blade, Vaadin & Co 5
D Spring Anfänger benötigt Hilfe Frameworks - Spring, Play, Blade, Vaadin & Co 9
OnDemand Spring Boot seltsame Logeinträge: Manipulationsversuche? Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Spring Date keine neue Tabelle fuer Attribut Frameworks - Spring, Play, Blade, Vaadin & Co 1
T Spring Security Config File anpassen Frameworks - Spring, Play, Blade, Vaadin & Co 1
8u3631984 Spring Cloud : Resttemplate mit Loadballancer Frameworks - Spring, Play, Blade, Vaadin & Co 11
Dimax Spring resource not found Frameworks - Spring, Play, Blade, Vaadin & Co 2
M Spring MongoDB unique index Frameworks - Spring, Play, Blade, Vaadin & Co 3
M Spring Entity testen Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Entity testen Frameworks - Spring, Play, Blade, Vaadin & Co 5
Dimax Spring App Probleme beim Ausführen auf dem Tomcat Server Frameworks - Spring, Play, Blade, Vaadin & Co 1
D Spring WebFlux Cors konfigurieren Frameworks - Spring, Play, Blade, Vaadin & Co 1
Dimax Schöne View mit anchor scrolling in Spring Frameworks - Spring, Play, Blade, Vaadin & Co 2
Dimax Spring JPA Multiple Keys Frameworks - Spring, Play, Blade, Vaadin & Co 3
S Spring Security mit oauth2 in lokaler Konfiguration principal mocken Frameworks - Spring, Play, Blade, Vaadin & Co 0
D Spring Boot Mile Stone und Snapshot Versionen Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Boot Exception Body Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Was ist das Framework "Spring"? Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Unit/Integrations Testing Frameworks - Spring, Play, Blade, Vaadin & Co 3
D Spring Unit Test: UnsatisfiedDependencyException: Error creating bean with name Frameworks - Spring, Play, Blade, Vaadin & Co 2
H Resource Liste Lazy Autowired Spring Context Frameworks - Spring, Play, Blade, Vaadin & Co 2
M Java Spring Security Frameworks - Spring, Play, Blade, Vaadin & Co 5
M Spring Security Login with Credentials Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Spring Boot - Overkill für private Projekte? Frameworks - Spring, Play, Blade, Vaadin & Co 3
krgewb Spring und GWT - & wird zu & amp; Frameworks - Spring, Play, Blade, Vaadin & Co 2
K Migration eines internen Frameworks zu Spring:Boot Frameworks - Spring, Play, Blade, Vaadin & Co 0
OnDemand JPA/Spring Repository Like Suche leeres Ergebnis Frameworks - Spring, Play, Blade, Vaadin & Co 0
Z Hibernate & Postgres in Spring Boot (Syntaxprobleme) Frameworks - Spring, Play, Blade, Vaadin & Co 2
Z Spring Boot mit JPA;, Hibernate, Rest & Lombok Frameworks - Spring, Play, Blade, Vaadin & Co 8
M Spring Initializer - Webservices Frameworks - Spring, Play, Blade, Vaadin & Co 0
D Spring Hateoas Frameworks - Spring, Play, Blade, Vaadin & Co 1

Ähnliche Java Themen

Neue Themen


Oben