• 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ć

Object Storage Arubacloud
0 głosów
585 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ź 610 wizyt
pytanie zadane 19 lipca 2020 w Java przez matiibal Użytkownik (620 p.)
0 głosów
2 odpowiedzi 245 wizyt
pytanie zadane 28 sierpnia 2018 w Java przez Pablo93 Użytkownik (800 p.)
0 głosów
1 odpowiedź 158 wizyt
pytanie zadane 12 maja 2023 w Java przez Mikołaj Pątkowski Użytkownik (530 p.)

92,551 zapytań

141,399 odpowiedzi

319,531 komentarzy

61,937 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.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...