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

Dwa obce klucze w jednej tabeli odnoszące się do jednego klucza podstawowego

Hosting forpsi easy 1 pln
0 głosów
2,548 wizyt
pytanie zadane 27 lipca 2017 w SQL, bazy danych przez plkpiotr Stary wyjadacz (12,420 p.)
edycja 27 lipca 2017 przez plkpiotr

Stworzyłem trzy tabele w bazie danych: players, matches i messages:

CREATE TABLE `players` (
  `id` int(11) NOT NULL,
  `name` varchar(15) COLLATE utf8_polish_ci NOT NULL,
  `surname` varchar(20) COLLATE utf8_polish_ci NOT NULL,
  `nick` varchar(10) COLLATE utf8_polish_ci NOT NULL,
  `team` varchar(20) COLLATE utf8_polish_ci NOT NULL,
  `sex` varchar(5) COLLATE utf8_polish_ci NOT NULL,
  `avatar` varchar(11) COLLATE utf8_polish_ci NOT NULL,
  `birth` date NOT NULL,
  `number_matches_won` int(11) NOT NULL,
  `number_matches_lost` int(11) NOT NULL,
  `number_sets_won` int(11) NOT NULL,
  `number_sets_lost` int(11) NOT NULL,
  `number_points_scored` int(11) NOT NULL,
  `number_points_lost` int(11) NOT NULL,
  `password` varchar(64) COLLATE utf8_polish_ci NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_polish_ci;
CREATE TABLE `matches` (
  `id` int(11) NOT NULL,
  `team` varchar(20) COLLATE utf8_polish_ci NOT NULL,
  `home` int(11) NOT NULL,
  `away` int(11) NOT NULL,
  `result_home` tinyint(4) NOT NULL,
  `result_away` tinyint(4) NOT NULL,
  `first_set_home` tinyint(4) NOT NULL,
  `first_set_away` tinyint(4) NOT NULL,
  `second_set_home` tinyint(4) NOT NULL,
  `second_set_away` tinyint(4) NOT NULL,
  `third_set_home` tinyint(4) NOT NULL,
  `third_set_away` tinyint(4) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_polish_ci;
CREATE TABLE `messages` (
  `id` int(11) NOT NULL,
  `date` datetime NOT NULL,
  `content` varchar(300) COLLATE utf8_polish_ci DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_polish_ci;

Gdzie klucze podstawowe określone są jak niżej:

ALTER TABLE `matches`
  ADD PRIMARY KEY (`id`);

ALTER TABLE `messages`
  ADD PRIMARY KEY (`date`);

ALTER TABLE `players`
  ADD PRIMARY KEY (`id`);

Chciałbym, aby messages.id było kluczem obcym klucza podstawowego players.id, co wykonałem poleceniem:

ALTER TABLE messages
   ADD FOREIGN KEY (id) REFERENCES players (id);

Czy poprawnie?
Zaś, aby matches.home i matches.away były kluczami obcymi klucza podstawowego players.id i tutaj nie wiem jak tą relację sprecyzować? Jeden do wielu? Czy po prostu dwa klucze obce w jednej tabeli?


Poniższe próby powodują błędy:

ALTER TABLE matches
   ADD FOREIGN KEY (home, away) REFERENCES players (id, id);
-- #1005
ALTER TABLE matches
   ADD FOREIGN KEY (home) REFERENCES players (id)
...
ALTER TABLE matches
   ADD FOREIGN KEY (away) REFERENCES players (id)
-- #1452

Dwa obce klucze w jednej tabeli odnoszące się do jednego klucza podstawowego? Czy jest to możliwe?

1 odpowiedź

0 głosów
odpowiedź 31 lipca 2017 przez plkpiotr Stary wyjadacz (12,420 p.)
 
Najlepsza

Analogiczna sytuacja z zapytaniem SELECT:

Forum PHP PL - "dwa klucze obce z jednej tabeli"

Podobne pytania

0 głosów
0 odpowiedzi 328 wizyt
pytanie zadane 14 lipca 2019 w PHP przez niezalogowany
0 głosów
1 odpowiedź 1,011 wizyt
pytanie zadane 29 listopada 2017 w SQL, bazy danych przez olszew6018 Nowicjusz (160 p.)
0 głosów
1 odpowiedź 173 wizyt
pytanie zadane 18 grudnia 2017 w Rozwój zawodowy, nauka, praca przez LockeLamora Użytkownik (740 p.)

92,125 zapytań

140,785 odpowiedzi

317,804 komentarzy

61,446 pasjonatów

Advent of Code 2023

Top 15 użytkowników

  1. 1468p. - Łukasz Eckert
  2. 1444p. - Dawid128
  3. 1430p. - CC PL
  4. 1419p. - rafalszastok
  5. 1418p. - Marcin Putra
  6. 1373p. - Mikbac
  7. 1362p. - rucin93
  8. 1351p. - sefirek
  9. 1325p. - Michal Drewniak
  10. 1296p. - Adrian Wieprzkowicz
  11. 1267p. - Eryk Andrzejewski
  12. 1260p. - TheLukaszNs
  13. 1239p. - JarekDev
  14. 1188p. - Rafał Trójniak
  15. 1179p. - 13NOONE37
Szczegóły i pełne wyniki

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.

Uwaga - w dniach od 02.12 do 08.12 trwają Mikołajki (książki drukowane mają rabat -35%, ebooki do -45%). Zaś dodatkowy, specjalny kod zniżkowy: HELMIKOLAJ-10 dla naszych Widzów zapewni Wam oszczędność -10zł dla zamówień powyżej 70zł! Warto korzystać!

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...