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

MYSQL błąd 42601 praca domowa

VPS Starter Arubacloud
0 głosów
403 wizyt
pytanie zadane 27 maja 2021 w SQL, bazy danych przez ANONIM2137 Początkujący (300 p.)
edycja 27 maja 2021 przez ANONIM2137

Dzień dobry mam problem pracą domową. Mianowicie wyskakuje mi błąd. 42601 Niżej przesyłam kod. Tutaj masz pełny komunikat:

DROP TABLE IF EXISTS miasto CASCADE;
CREATE TABLE miasto (
id_miasta serial NOT NULL,
nazwa_miasta VARCHAR(50) NOT NULL DEFAULT 'SANDOMIERZ',
kod_pocztowy VARCHAR(7) NOT NULL,
id_panstwa int not null,
CONSTRAINT miasto_pk PRIMARY KEY (id_miasta),
CONSTRAINT miasto_fk FOREIGN KEY (id_panstwa) REFERENCES (id_panstwa)
);

 

1
komentarz 27 maja 2021 przez niezalogowany
pokaż proszę pełny komunikat błędu, który wypluwa konsola.
komentarz 27 maja 2021 przez niezalogowany

@ANONIM2137,

linia numer 6

id_panstwa int not null

powinno być ?

id_panstwa int NOT NULL

komentarz 27 maja 2021 przez ANONIM2137 Początkujący (300 p.)
powinno lecz nie pomaga

1 odpowiedź

+1 głos
odpowiedź 27 maja 2021 przez Wiciorny Ekspert (269,120 p.)
edycja 27 maja 2021 przez Wiciorny

DEFAULT to wartość, która zostanie wstawiona w przypadku braku jawnej wartości w instrukcji wstawiania / aktualizowania. Załóżmy, że Twój DDL nie ma ograniczenia NOT NULL, problem wynika z tego - że kolumna nie będzie nigdy NOT NULL bo jeśli nie zostanie wprowadzona wartość od użytkownika, to DEFULT zawsze WYKONUJE SIĘ PRZED SPRAWDZENIEM NOT NULL.
 

id_miasta serial NOT NULL,

jeśli robisz serial, to nie robisz NOT NULL  bo 
SERIAL to alias dla BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE.

Tworzysz FOREIGN KEY  pamiętaj żę tabela do której się ODWOŁUJESZ musi już istnieć wcześniej. 

REFERENCES (id_panstwa) - tu masz błąd? nie wskazałeś tabeli :) 
REFERENCES NAZWA_TABELI(id_panstwa)

 

 

Składnia

Ograniczenie w jednym polu:

CONSTRAINT nazwa {PRIMARY KEY | UNIQUE | NOT NULL |
REFERENCES tabelaobca [(poleobce1, poleobce2)]
[ON UPDATE CASCADE | SET NULL]
[ON DELETE CASCADE | SET NULL]}

Ograniczenie w wielu polach:

CONSTRAINT nazwa
{PRIMARY KEY (klucz_podstawowy1[, klucz_podstawowy2 [, ...]]) |
UNIQUE (klucz_unikatowy1[, klucz_unikatowy2 [, ...]]) |
NOT NULL (pole_niepuste1[, pole_niepuste2 [, ...]]) |
FOREIGN KEY [NO INDEX] (odw1[, odw2 [, ...]]) REFERENCES tabelaobca [(pole_tabeli_obcej1 [, pole_tabeli_obcej2 [, ...]])]
[ON UPDATE CASCADE | SET NULL]
[ON DELETE CASCADE | SET NULL]}

Podobne pytania

0 głosów
0 odpowiedzi 269 wizyt
pytanie zadane 27 maja 2021 w Java przez ANONIM2137 Początkujący (300 p.)
+1 głos
2 odpowiedzi 2,917 wizyt
pytanie zadane 1 maja 2015 w SQL, bazy danych przez ArturB Mądrala (6,060 p.)
0 głosów
1 odpowiedź 616 wizyt

92,454 zapytań

141,262 odpowiedzi

319,099 komentarzy

61,854 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

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!

...