• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Java Spring JPA Relacje, jak zapisać

0 głosów
908 wizyt
pytanie zadane 17 marca 2020 w Java przez Placidus Użytkownik (580 p.)

Witam posiadam dajmy na to dwie tabele

Street(id, name)

Street_number(id , number)

Do tego tworzę encję w javie;

@Entity
public class Street {
    @Id
    private Long id;
    private String name;
    
}
@Entity
public class StreetNumber {
    @Id
    private Long id;
    private String number;
}

mam do tego IStreetService, StreetSerivce, StreetRepository i to samo dla StreetNumber oraz Api.

Wiem jak działać na pojedynczych tabelach.

Teraz chciałbym się dowiedzieć jak tworzyć relację miedzy nimi i czy to będzie relacja ManyToMany ?

Może być wiele ulic i do każdej przypisanych wiele numerów.

Jeszcze jedno pytanie, czy może lepiej robić to wszystko przez JdbcRepo ? Już w tym trochę ćwiczyłem.

1 odpowiedź

+1 głos
odpowiedź 17 marca 2020 przez Paweł Nąckiewicz Nałogowiec (48,990 p.)
wybrane 17 marca 2020 przez Placidus
 
Najlepsza

Trochę słaby przykład bo dla mnie to jest cały czas obiekt Adress...

Jeśli jednak tak do tego chcesz podejść to powinna tutaj wystapić relacja many to many (wiele ulic może mieć wiele numerów mieszkań).

Wtedy robisz coś takiego:

public class StreetNumber{

    @Id
    @GeneratedValue
    private Long id;

    @NonNull
    private String number;

    @ManyToMany( mappedBy = "name")
    private Collection<Street> streets;

}

private class Street {

    @Id
    @GeneratedValue
    private Long id;
    

    @ManyToMany(fetch = FetchType.EAGER)
    @JoinTable(
            name = "street_numberss",
            joinColumns = @JoinColumn(name = "street_id",referencedColumnName = "id"),
            inverseJoinColumns = @JoinColumn(name = "number_id",referencedColumnName = "id")
    )
    private Set<StreetNumber> numbers = new HashSet<>();
}

Tak jak mówie dla mnie przykład bez sensu, ale podam Ci to samo zastosowanie dla lepszego przykładu. Masz Usera, który może mieć kilka ról. 

@Entity

public class User{

    @Id @GeneratedValue
    private Long id;

    @ManyToMany(fetch = FetchType.EAGER)
    @JoinTable(
            name = "users_roles",
            joinColumns = @JoinColumn(name = "user_id",referencedColumnName = "id"),
            inverseJoinColumns = @JoinColumn(name = "role_id",referencedColumnName = "id")
    )
    private Set<Role> roles = new HashSet<>();

    @NonNull
    private String firstName;

    @NonNull
    private String lastName;
}

@Entity
public class Role {

    @Id
    @GeneratedValue
    private Long id;

    @NonNull
    private String name;

    @ManyToMany( mappedBy = "roles")
    private Collection<User> users;

}


 

komentarz 17 marca 2020 przez Placidus Użytkownik (580 p.)

żeby to się wszystko tworzyło musi być hibernate tak? w application.properties

spring.jpa.hibernate.ddl-auto=create
spring.jpa.database-platform=org.hibernate.dialect.MySQL57Dialect
spring.jpa.generate-ddl=true
spring.jpa.show-sql=true

znalazłem coś takiego

komentarz 17 marca 2020 przez Paweł Nąckiewicz Nałogowiec (48,990 p.)
Tak potrzebujesz hibernata. Umożliwia on dokonania mapowania obiektowo-relacyjnego (ORM) – czyli odwzorowania obiektów klas na bazę danych. Twoja konfiguracja wyglad OK.

Podobne pytania

0 głosów
1 odpowiedź 1,173 wizyt
pytanie zadane 19 lipca 2020 w Java przez matiibal Użytkownik (620 p.)
0 głosów
2 odpowiedzi 403 wizyt
pytanie zadane 28 sierpnia 2018 w Java przez Pablo93 Użytkownik (800 p.)
0 głosów
1 odpowiedź 357 wizyt
pytanie zadane 12 maja 2023 w Java przez Mikołaj Pątkowski Użytkownik (530 p.)

93,603 zapytań

142,526 odpowiedzi

322,993 komentarzy

63,086 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Kursy INF.02 i INF.03
...