Diskuze: Návrh databázy MSSQL - ako zvoliť?
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 7 zpráv z 7.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Hlavní zásada návrhu DB je ta, že by se záznamy v jedné tabulce měly týkat stejné oblasti. Tím myslím, že by se neměly míchat záznamy do jedné tabulky(údaje z faktury, údaje o produktech, údaje o zákazníkovi, atd. by měly mít každý svoji tabulku).
je to jedna oblasť. Rezervácia ubytovania, kde je v budove cca 300 izieb, a
na každú postel v budove (sú jedno aj dvojpostelové izby) je rezerácia na
celý rok, kde chcem ukladať meno, priezvisko, bydlisko, id a čas nastupu a
odchodu na každú izbu (posteľ(lôžko)).
alebo výhodnejšie do databazy s lôžkami dať len "id" ubytovaného a v
ďalšej databáze mať k danému "id" dalšie udaje o ubytovanom (meno,
bydlisko, číslo pasu, atď... )
Určitě je potřeba rozsekat to do samostatných tabulek (zákazníci,
pokoje, rezervace atd.) a propojit to přes primární/cizí klíče. Určitě
bych nedělal sloupeček pro každý pokoj (možná jsem to jen špatně
pochopil), ale udělal bych si tabulku se seznamem pokojů a do rezervace pak
ukládal jen jeho ID. To ti umožní přidávat/odebírat pokoje a hlavně
nějak rozumě s těmi daty pracovat.
Jak už tu bylo řečeno, v každé tabulce by měla být data která spolu
souvisejí. Zkus to rozsekat na jednotlivé oblasti a ty dát k sobě. Pak už
ti z toho struktura databáze tak nějak vyplyne. Počtu řádků se neboj, SQL
Server zvládne mnohem mnohem víc než popisuješ, ale 300 sloupců v jedné
tabulce mi příjde moc na rezervační systém, bude se s tím blbě
pracovat.
Ono mne sa bude v c# lepšie pracovať s riadkami databázy ako a poliami,
ide mi však aj o zahltenie siete - bude niekolko počítačov v sieti a čo
menej zaťaží sieť?
ak načítam jeden riadok databázy s 300 poľami, alebo 300 riadkov s jedným
poľom?
chcem graficky znázorniť ubytovací systém prehladne na jednom formulári
všetkých 300 izieb, kde budu farebne označené volné zelenou a obsadené
červenou , a na to potrebujem načítať dáta o celej ubytovacej kapacite.
Čo myslíš, čo menej zaťaží a zahltí sieť? Nie je tam optika, ani 1G,
iba 100M eternet (sú väčšie vzdialenosti medzi počítačmi - 50-90m)
Nejde o zahlcení sítě, ale o délku zpracování dotazu. Když se server bude muset probírat jednou tabulkou o 300 sloupcích, myslím si, že kdyby měl ruce, tak tě něčím bací.
Zobrazeno 7 zpráv z 7.