Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> Dwa klucze główne w jeden tabeli
dan0123
post 5.02.2012, 11:06:17
Post #1





Grupa: Zarejestrowani
Postów: 1
Pomógł: 0
Dołączył: 5.02.2012

Ostrzeżenie: (0%)
-----


Witam,
Kiedy należy stosować / stosuje się więcej niż 1 klucz główny w 1 tabeli (encji) ?

Wiem że takie "zjawisko" istnieje, ale nie znalazłem powodu kiedy należy się do tego zastosować. Jeżeli ktoś nie rozumie o co mi chodzi to chodzi mi o sytuację, gdy podczas tworzenia tabeli (create table) jako pierwszy klucz główny ustawiamy pole standardowe tj. id_, a jako drugi klucz główny ustawiamy pole, które powinno być (TEORETYCZNIE) kluczem obcym, a jest ustawiane jako klucz główny (PRIMARY KEY).

Podam przykład o co mi chodzi, pewnie nie adekwatny do powodu zastosowania dwóch primary key, ale zobrazuje to lepiej mój problem:
Mamy dwie tabele:
STUDENCI( id_studenta, imie, nazwisko, pesel, nr_indeksu, id_oceny )
OCENY( id_oceny, ocena_Cyfra, ocena_Slownie )

I przy tworzeniu tabeli STUDENCI ustawiamy PRIMARY KEY na dwa pola tj. id_studenta oraz id_oceny. Dlaczego użycie takiego czegoś jest poprawne ? Dlaczego nie jest lub jest poprawne w tym przypadku ? Kiedy to stosować ? Jakie są korzyści z zastosowania tego sposobu ?

Korzystam z bazy danych Oracle, ale chyba to nie ma znaczenia w tej kwestii.

Pozdrawiam.

Ten post edytował dan0123 5.02.2012, 11:06:35
Go to the top of the page
+Quote Post
viking
post 5.02.2012, 11:18:58
Post #2





Grupa: Zarejestrowani
Postów: 6 376
Pomógł: 1116
Dołączył: 30.08.2006

Ostrzeżenie: (0%)
-----


A jakie jest zadanie klucza głównego? Jednoznaczne zidentyfikować rekord. Zazwyczaj polega to na podaniu dodatkowego pola (w oracle number z sekwencją). Twój problem opiera się na właściwym doborze kluczy kandydujących ale najlepiej będzie jak poczytasz trochę teorii na ten temat. Tak na oko ciekawy wątek do poczytania http://groups.google.com/group/pl.comp.baz...3f78180013a7e5a


--------------------
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 7.05.2025 - 07:56