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

Bazy danych sql, kwerenda działająca na trzech tabelkach

0 głosów
252 wizyt
pytanie zadane 10 stycznia 2018 w Rozwój zawodowy, nauka, szkoła, praca przez tma Nowicjusz (160 p.)
Witam, mam problem ze stworzeniem kwerendy w sql.

Posiadam Tabelkę A która jest kluczem głównym oraz tabelki B, C, D powiązane z tabelką A kluczem obcym. Problem jest taki, że tabelka D jest opcjonalna(posiada null). Potrzebuję wypisać wszystkie dane z tabelki B, C oraz D (jeśli takie istnieją), które są połączone z A wartością '8'  

Potrafię to zrobić zwykłym wherem oraz łącznikami AND i OR jeśli do tabelki D opcjonalnej wpiszę wartość z klucza głownego 8, jeśli jednak jest on pusty (co jest dla mnie ważne) kwerenda się sypie i wywala empty set

Nie będę wrzucał tej kwerendy tutaj gdyż są to zagmatwane tabele pośednie. Chciałbym aby ktoś napisał to ona tych literkach a ja sobie przeanalizuje i przerzucę do swojej bazy ;)
komentarz 10 stycznia 2018 przez Tomek Sochacki Ekspert (229,500 p.)
Możesz dać na http://sqlfiddle.com/

A tak na marginesie to jeśli robisz takie połączenia wielu tabel to fajnie jest potworzyć sobie widoki na bazie i potem w aplikacji masz proste selecty do widoku bez żadnych złączeń i innej "logiki" bazy.
komentarz 14 stycznia 2018 przez tma Nowicjusz (160 p.)
Ja właśnie potrzebuje tą całą logikę bazy :(

2 odpowiedzi

0 głosów
odpowiedź 10 stycznia 2018 przez Wiciorny Ekspert (237,370 p.)
Poczytaj o Inner JOIN  z typu LEFT- RIGHT Join :) na odpowiednich kolumnach,
komentarz 14 stycznia 2018 przez tma Nowicjusz (160 p.)
Wiem jak to działa, problem jest troszkę inny. Zaraz zaaktualizuje.
0 głosów
odpowiedź 14 stycznia 2018 przez tma Nowicjusz (160 p.)

Diagram mojej bazy danych wygląda następująco:

Potrzebuję wypisać nazwę diety, nazwę ćwiczenia, ilość serii, ilość powtórzeń oraz nazwę suplementu. Mój select póki co działa tylko wtedy, jeśli do kogoś był przypisany suplement, jeśli takowego nie było (a jest związek opcjonalny i możę się tak wydarzyć) wtedy też powinno wyświetlać tylko, że w nazwa suplementu np. 'brak'.

Mój obecny select działa, ale gdy usunę w tabeli pośredniej suplementacje (która musi być opcjonalna) - pokazuje empty set. Jak mogę go edytować tak, aby przy braku suplementacji wpisywał automatycznie 'brak'?

select d.nazwa_dieta, t.nazwa_cwiczenia,t.ilosc_serii,t.ilosc_powtorzen,s.nazwa_suplementu from dieta as d, trening as t, suplementacja as s, historia_zmian as h,historia_zmian_dieta as hd,historia_zmian_trening as ht,historia_zmian_suplementacja as hs where h.id_historia=hd.id_historia and hd.id_dieta=d.id_dieta and h.id_historia=ht.id_historia and ht.id_trening=t.id_trening and h.id_historia=hs.id_historia and hs.id_suplementacja=s.id_suplementacja and h.id_historia='5'

 

Pozdrawiam

 

Podobne pytania

0 głosów
1 odpowiedź 130 wizyt
pytanie zadane 3 lipca 2018 w PHP przez ojejj Początkujący (350 p.)
+1 głos
0 odpowiedzi 71 wizyt
pytanie zadane 10 maja 2021 w SQL, bazy danych przez Bartek030 Obywatel (1,460 p.)
0 głosów
1 odpowiedź 96 wizyt
pytanie zadane 23 sierpnia 2017 w SQL, bazy danych przez Bartess Gaduła (3,600 p.)

89,664 zapytań

138,268 odpowiedzi

309,178 komentarzy

59,602 pasjonatów

Motyw:

Akcja Pajacyk

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

Sklep oferujący ćwiczenia JavaScript, PHP, rozmowy rekrutacyjne dla programistów i inne materiały

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...