-
Data: 2009-12-17 19:40:29
Temat: Re: Pytanie o klucze baz
Od: wloochacz <w...@n...dgbit.spameromnie.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Mateusz Loskot pisze:
> "Jacek Czerwinski" <...@...z.pl> wrote in message
> news:hgdlor$ndl$1@news.onet.pl...
>> Krzysztof Warunek pisze:
>>> W dniu 2009-12-17 13:56, Jacek Czerwinski pisze:
>>
>>>> Praktyka, na czele z MS-SQL z którym ostatnio często się spotykam,
>>>> niemal wymusza pojedynczy klucz pierwotny (automatycznie wypełniany,
>>>> liczbowy i niezmienny).
>>> co w tym złego?
>>
>> Raczej dobrego, dość to pozytywnie odbieram.
>
> Widziałem "standardy kodowania" dla baz, gdzie
> automagicznie generowany klucz jest wręcz zalecany
> i oczywiście niezmienny w trakcie jakichkolwiek operacji typu UPDATE
>
> Istnieją sytuacje w których klucz główny (primary key) w ogóle nie jest
> ustalany a istnieje kilka kombinacji (candidate key) pozwalające
> na unikalne ustalenie rekordu, zależnie od potrzeb i zapytań.
To nie jest dobry pomysł - nigdy; jak do takiej tabeli dodać relację np.
jeden-do-wielu? Za pomoca triggera? Fuj - jeszcze trzeba by dodać indeks
dodac na tej nowej tabelce, bo inaczej wyszukiwanie będzie się ślimaczyć...
Poza tym pytaczowi nie chodziło o candidate key, tylko o natural primary
key - imo.
Generalnie - cały temat rozbija się o dwie kwestie:
1) klucz naturalny jest wygodny, ponieważ nie trzeba łączyć tabel, żeby
user widział co to za id jest. On to po prostu widzi. Wada to taka, że
to user powinien taki klucz zakładać - inaczej nie ma sensu, bo
dochodzimy do generowanego automagicznie (identity, guid)
2) klucz złożony, czasem wydaje się dobrym pomysłem - do czasu jeśli nie
zechcemy dodać podrzędnej tabeli i zdefiniować klucza obcego - trzeba te
wszystkie wartości z tabli nadrzędnej pieczłowicie przepisać do
podrzędnej. A na dodatek informacja jest nadmiarowa.
IMO zamiast podstawowego klucza złożonego, lepiej zrobić sztyczny PK +
ograniczenie typu unique.
Co do kluczy naturalnych - czasem, ale to naprawdę czasami - jest
przydatny i to naprawdę zależy od tego co to za aplikacja i jakiego
rodzaju dane obrabia.
Znam pewien ERP, gdzie PK (i ID w app) jest tylko i wyłącznie kluczem
naturalnym - user musi wszystko wpisać z łapy (id towaru, id klienta, id
magazynu itd.). I to działa i nawet mi to nie przeszkadza :)
--
wloochacz
Następne wpisy z tego wątku
- 17.12.09 20:10 HillBilly
- 17.12.09 21:38 Bronek Kozicki
- 18.12.09 08:03 wloochacz
- 18.12.09 09:42 Mateusz Ludwin
- 25.12.09 18:55 gregorius
Najnowsze wątki z tej grupy
- TCL - problem z escape ostatniego \ w nawiasach {}
- Nauka i Praca Programisty C++ w III Rzeczy (pospolitej)
- testy-wyd-sort - Podsumowanie
- Tworzenie Programów Nieuprzywilejowanych Opartych Na Wtyczkach
- Do czego nadaje się QDockWidget z bibl. Qt?
- Bibl. Qt jest sztucznie ograniczona - jest nieprzydatna do celów komercyjnych
- Co sciaga kretynow
- AEiC 2024 - Ada-Europe conference - Deadlines Approaching
- Jakie są dobre zasady programowania programów opartych na wtyczkach?
- sprawdzanie słów kluczowych dot. zła
- Re: W czym sie teraz pisze programy??
- Re: (PDF) Surgical Pathology of Non-neoplastic Gastrointestinal Diseases by Lizhi Zhang
- CfC 28th Ada-Europe Int. Conf. Reliable Software Technologies
- Młodzi programiści i tajna policja
- Ada 2022 Language Reference Manual to be Published by Springer
Najnowsze wątki
- 2024-11-08 Belka
- 2024-11-09 pierdolec na punkcie psa
- 2024-11-09 Warszawa => Sales Executive <=
- 2024-11-09 Wrocław => SAP BTP Consultant (mid/senior) <=
- 2024-11-09 Warszawa => ECM Specialist / Consultant <=
- 2024-11-09 Warszawa => Senior Frontend Developer (React + React Native) <=
- 2024-11-10 TVN donosi: Obywatelskie zatrzymanie policjanta (nie na służbie)
- 2024-11-08 Warszawa => Head of International Freight Forwarding Department <=
- 2024-11-08 Warszawa => Key Account Manager <=
- 2024-11-08 Szczecin => Key Account Manager (ERP) <=
- 2024-11-08 Białystok => Full Stack web developer (obszar .Net Core, Angular6+) <
- 2024-11-08 Wrocław => Senior PHP Symfony Developer <=
- 2024-11-08 Warszawa => QA Engineer <=
- 2024-11-08 Warszawa => QA Inżynier <=
- 2024-11-08 Warszawa => Key Account Manager <=