Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Błąd przy tworzeniu tabeli
Forum PHP.pl > Forum > Bazy danych > Oracle
dexter22
Gdy tworzę

create table pracownicy ( idi varchar2(5) not null constraint references instytut_fkey instytut ); mam taki oto błąd:

constraint specification not allowed here
nospor
Komunikat błędu chyba wszystko wyjaśnia w 100%
dexter22
Mam usunąć specyfikator ograniczenia z oświadczenia. czyli constraint refereces??
nospor
Dawno nie bawiłem się oraclem, ale jak zaglądam do dokumentacji to widzę, że po definicji kolumny a przed constrait jest przecinek a u ciebie nie ma.
dexter22
Nadal nie trybi.. Jakieś pomysły?
nospor
Nadal ten sam błąd? Pokaz kod po poprawkach
dexter22
create table pracownicy (
idi varchar2(5) not null, constraint reference instytut_fkey idi);
mortus
Bo prawidłowo zależności definiujesz tak:
CONSTRAINT nazwa_zależności REFERENCES nazwa_tabeli (opcjonalnie_nazwa_kolumny)
Zatem:
  1. -- tak:
  2. CREATE TABLE pracownicy (
  3. idi varchar2(5) NOT NULL CONSTRAINT instytut_fkey REFERENCES instytut
  4. );
  5. -- lub tak:
  6. CREATE TABLE pracownicy (
  7. idi varchar2(5) NOT NULL CONSTRAINT instytut_fkey REFERENCES instytut (idi)
  8. );
  9. -- lub tak:
  10. CREATE TABLE pracownicy (
  11. idi varchar2(5) NOT NULL,
  12. CONSTRAINT instytut_fkey REFERENCES instytut (idi)
  13. );
dexter22
bardzo dziękuję, działa :-) Tak jak pisałem na samym początku podawała nam doktor.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2024 Invision Power Services, Inc.