Spring JPA Probleme beim SPeichern von Sets

8u3631984

Bekanntes Mitglied
Hallo ich bin dabei ein Photo Album App zu programmieren.
Kurz zur Idee :
  • Das Programm soll aus einem Verzeichnis jpg Bilder auszulesen und daraus Meta Data zu ermittel und in einem PhotoItem zu speichern. Dieses PhotoItem soll dann in einem PhotoAlbum Object abgespeichert werden.
Hier die entsprechenden Klassen :
Java:
@AllArgsConstructor
@NoArgsConstructor
@Builder(setterPrefix = "with")
@Getter
@Entity
@Table(name = "PHOTO_ITEM")
@ToString
public class PhotoItem implements Item {

    @Id
    @GeneratedValue
    @Column(updatable = false)
    private long ID;

    @NonNull
    @Builder.Default
    private String hashValue = Strings.EMPTY;

    @NonNull
    @OneToOne(cascade = CascadeType.ALL)
    private PhotoMetaData metaData;

    @NonNull
    @OneToOne(cascade = CascadeType.ALL)
    private PhotoLocation location;
}


Java:
@AllArgsConstructor
@NoArgsConstructor
@Builder(setterPrefix = "with")
@Getter
@Entity
@Table(name = "PHOTO_METADATA")
@ToString
public class PhotoMetaData implements DatabaseEntity {

        @Id
        @GeneratedValue
        @Column(updatable = false)
        private long ID;

        private int height;

        private int width;

        @NonNull
        @Builder.Default
        private String creationTimeStampAsString = Strings.EMPTY;

        private double latitude;

        private double longitude;
}


Java:
@AllArgsConstructor
@NoArgsConstructor
@Builder(setterPrefix = "with")
@Getter
@Entity
@Table(name = "PHOTO_LOCATION")
@ToString
public class PhotoLocation implements Location {

    @Id
    @GeneratedValue
    @Column(updatable = false)
    private long ID;

    @NonNull
    @Builder.Default
    private String country = Strings.EMPTY;

    @NonNull
    @Builder.Default
    private String city = Strings.EMPTY;

    @NonNull
    @Builder.Default
    private String postCode = Strings.EMPTY;

    @NonNull
    @Builder.Default
    private String street = Strings.EMPTY;

    @NonNull
    @Builder.Default
    private String houseNumber = Strings.EMPTY;
}

Java:
@AllArgsConstructor
@NoArgsConstructor
@Builder(setterPrefix = "with", toBuilder = true)
@Getter
@Entity
@Table(name = "PHOTO_ALBUM")
@ToString
public class PhotoAlbum implements Album {

        @Id
        @GeneratedValue
        @Column(updatable = false)
        private long ID;

        @NonNull
        @Builder.Default
        private String name = Strings.EMPTY;

        @NonNull
        @Singular
        @ManyToMany(fetch = FetchType.EAGER, cascade = CascadeType.ALL)
        private Set<PhotoItem> albumItems;
}

hier die Stelle wo die Bilder aus dem Verzeichnis gelesen und in eine Photo Item gebaut werden :

Java:
        var photoFiles = FileUtils.listFiles(new File(sourceFolder), new String[] { "jpg" }, true);
        var photoItems = Sets.newHashSet(photoFiles.stream().map(photoItemService::buildPhotoItem).toList());

        var photoAlbum = PhotoAlbum.builder()
                .withName(photoAlbumName)
                .withAlbumItems(photoItems)
                .build();

        var existingPhotoAlbum = getIfExists(photoAlbumName);
        if (existingPhotoAlbum.isPresent()) {
            log.info("{}", kv("existing photo album", photoAlbum));
            var existingPhotoItems = existingPhotoAlbum.get().getAlbumItems();

            photoAlbum = photoAlbum.toBuilder()
                    .withAlbumItems(existingPhotoItems)
                    .build();
        }

        var savedPhotoAlbum = repository.save(photoAlbum);
        log.info("{}", kv("saved photo album", savedPhotoAlbum));
        return savedPhotoAlbum;

Ich hoffe, der Code ist einigermaßen verstädnis.
Die zeile var savedPhotoAlbum = repository.save(photoAlbum); führt dann zu einer Excepption :
Caused by: org.hibernate.PersistentObjectException: detached entity passed to persist: my.photoalbum.photoItem.PhotoItem

Der Fehler tritt im folgenden Fall auf :
Code:
     var photoAlbumName = "TestPhotoAlbum";
        var service = new PhotoAlbumService(repository, photoItemService);

        var photoAlbum1 = service.buildAndSavePhotoAlbum(photoAlbumName,
                Paths.get("src", "test", "resources", "TestPhotoAlbum", "Album1").toString());
     var photoAlbum2 = service.buildAndSavePhotoAlbum(photoAlbumName,
                Paths.get("src", "test", "resources", "TestPhotoAlbum", "Album2").toString());

Wenn das PhotoAlbum 2 gespeichert werden soll tritt der Fehler auf.
Ich hoffe ihr konntet einigermaßen nachvollziehen, was ich meine und habt evtl eine Idee wie ich das Problem lösen kann
 

KonradN

Super-Moderator
Mitarbeiter
Nach meinem Verständnis ist das Problem hier, dass Du doch bereits ein PhotoAlbum hast. Dieses lädst Du. Und dann erzeugst Du ein neues mit den Elementen des anderen PhotoAlbum.

Wieso hast Du das denn überhaupt so gemacht? Wieso verwendest Du nicht direkt das geladene PhotoAlbum Element? Dein Code macht so aus meiner Sicht keinen Sinn!

a) Die Prüfung, ob das PhotoAlbum bereits existiert, ist doch zuerst zu machen.
b) ist es nicht da, dann erzeugst Du es neu
c) ist es bereits da, dann nutzt Du das geladene Element.

Also - hier im Editor mal schnell editiert also ggf. mit Fehlern:
Java:
        var existingPhotoAlbum = getIfExists(photoAlbumName);
        if (existingPhotoAlbum.isPresent()) {
            log.info("{}", kv("existing photo album", photoAlbum));
            return existingPhotoAlbum.get();
        } else {
            var photoFiles = FileUtils.listFiles(new File(sourceFolder), new String[] { "jpg" }, true);
            var photoItems = Sets.newHashSet(photoFiles.stream().map(photoItemService::buildPhotoItem).toList());

            photoAlbum = PhotoAlbum.builder()
                .withName(photoAlbumName)
                .withAlbumItems(photoItems)
                .build();
            return repository.save(photoAlbum);
        }

Das dürfte von der Funktionalität dem entsprechen, das Du in deinem bisherigen Code hättest ... abgesehen davon, dass Dein Code nicht funktioniert, weil Du versuchst ein neues PhotoAlbum mit den gleichen Elementen zu erzeugen, die bereits in einem anderen PhotoAlbum vorhanden sind.
 

8u3631984

Bekanntes Mitglied
Hallo vielen Dank für deine Hilfe.
Der Gedanke war, dass ein PhotoAlbum aus mehrereren Verzeichnissen Bilder beinhalten kann. Außerdem kann auch in einem Verzeichnis ein neues bild hinzukommen. Ich scanne die Verzechnisse regelmäßig und aktualisieren dann das Album.
Ich habe meinen Code nun angepasst und nun klappt es :
Java:
        var photoAlbum = PhotoAlbum.builder()
                .withName(photoAlbumName)
                .build();
        var photoFiles = FileUtils.listFiles(new File(sourceFolder), new String[] { "jpg" }, true);
        log.info("{} in {}", kv("number of photo files", photoFiles.size()), kv("source folder", sourceFolder));
        var photoItems = Sets.newHashSet(photoFiles.stream().map(photoItemService::buildPhotoItem).toList());

        var existingPhotoAlbum = getIfExists(photoAlbumName);
        if (existingPhotoAlbum.isPresent()) {
            photoAlbum = existingPhotoAlbum.get();
            log.info("{}", kv("existing photo album", photoAlbum));
        }

        photoAlbum = photoAlbum.toBuilder().withAlbumItems(photoItems).build();

        var savedPhotoAlbum = repository.save(photoAlbum);
        log.info("{}", kv("saved photo album", savedPhotoAlbum));
        return savedPhotoAlbum;

Noch eine Nachfrage zu den Cascade Type : Ich habe bisher im mit ALL gearbeitet. Ist dies sinnvoll ?
 

KonradN

Super-Moderator
Mitarbeiter
Ich habe meinen Code nun angepasst und nun klappt es :
Sorry, aber das wage ich zu bezweifeln...

Java:
        var existingPhotoAlbum = getIfExists(photoAlbumName);
        if (existingPhotoAlbum.isPresent()) {
            photoAlbum = existingPhotoAlbum.get();
            log.info("{}", kv("existing photo album", photoAlbum));
        }

        photoAlbum = photoAlbum.toBuilder().withAlbumItems(photoItems).build();

Wenn das PhotoAlbum vorhanden ist, dann setzt Du die Variable photoAlbum.
Aber im Anschluss überschreibst Du den Wert mit einem neuen photoAlbum.

Du bekommst also den Fehler nicht mehr, weil Du die ursprünglichen Elemente nicht mehr hast. Der Code von Dir würde das gleiche machen, wenn Du diesen oben gezeigten Block bis auf die letzte Zeile entfernst.

Was Du willst, ist evtl. den Code von mir oben mit eine Anpassung wie:

Java:
        var photoFiles = FileUtils.listFiles(new File(sourceFolder), new String[] { "jpg" }, true);
        var photoItems = Sets.newHashSet(photoFiles.stream().map(photoItemService::buildPhotoItem).toList());
        PhotoAlbum photoAlbum;

        var existingPhotoAlbum = getIfExists(photoAlbumName);
        if (existingPhotoAlbum.isPresent()) {
            log.info("{}", kv("existing photo album", photoAlbum));
            photoAlbum = existingPhotoAlbum.get();
            photoAlbum.getAlbumItems().addAll(photoItems);
        } else {
            photoAlbum = PhotoAlbum.builder()
                .withName(photoAlbumName)
                .withAlbumItems(photoItems)
                .build();
        }

        return repository.save(photoAlbum);

Sprich: Wenn das PhotoAlbum geladen werden konnte, dann fügst Du nur noch die neuen photoItems hinzu. (So hatte ich Dich jetzt verstanden...).

Wichtig ist: Wenn es das PhotoAlbum bereits gibt, dann erzeugst Du kein Neues mehr!
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
8u3631984 Spring JDBC Probleme beim Spaltennamen Frameworks - Spring, Play, Blade, Vaadin & Co 3
Dimax Spring App Probleme beim Ausführen auf dem Tomcat Server Frameworks - Spring, Play, Blade, Vaadin & Co 1
Dimax Spring Security Probleme Frameworks - Spring, Play, Blade, Vaadin & Co 2
bueseb84 Probleme mit Spring Boot Docker und Bootstrap Frameworks - Spring, Play, Blade, Vaadin & Co 9
B Spring bean initialisierungs probleme Frameworks - Spring, Play, Blade, Vaadin & Co 0
H IE probleme mit multipartfile bei spring 3 anwendungen Frameworks - Spring, Play, Blade, Vaadin & Co 14
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
M Spring Boot 3 Datenbanken zur Laufzeit Verbinden Frameworks - Spring, Play, Blade, Vaadin & Co 5
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
L Spring Data und Rest Controller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
thor_norsk Spring Boot Fehler Frameworks - Spring, Play, Blade, Vaadin & Co 1
L Spring Data und Rest Conroller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
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
L Spring Data: Modellierung mit einer Embeddable bean Frameworks - Spring, Play, Blade, Vaadin & Co 2
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
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
ma095 Spring und Postgresql Errors Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring+Vaadin App startet nicht Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Spring Request externe API SSL Error Frameworks - Spring, Play, Blade, Vaadin & Co 7
OnDemand Spring Repo speichert, aber es kommt in der DB nicht an Frameworks - Spring, Play, Blade, Vaadin & Co 3
Dimax Im Spring ,Mysql-Funktion aufrufen Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Security/Boot/Vaadin Cookie Problem bei iFrame Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring Boot: Feld ignorieren Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Spring + Thymleaf : Checkbox Object mappen Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Buch zum Spring Framework bzw. Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 3
OnDemand Jasypt Spring Boot HIbernate wie komme ich an den Key? Frameworks - Spring, Play, Blade, Vaadin & Co 4
8u3631984 Spring Boot im Docker Container - Logback wird nicht verwendet Frameworks - Spring, Play, Blade, Vaadin & Co 13

Ähnliche Java Themen

Neue Themen


Oben