Michal Čižmár / 28. 03. 2007, 00:00
Tento diel bude zameraný na praktické ukážky vyhľadávania v DataSete, ďalej určenie primárnych kľúčov a hlavne na nastavenie vzťahov medzi tabuľkami. V jednom príklade si to ukážeme ako sa to spraví vizuálne a potom použije a raz manuálne - písaním kódu.
Predpokladám, že minulý článok máte zvládnutý a viete navrhnúť štruktúru tabuľky, ako vizuálne vo VisualStudiu, tak aj manuálne, naprogramovaním. Nebudem tu vysvetľovať do hĺbky, čo sú relácie medzi tabuľkami alebo primárne kľúče, na to som odporučil niektoré zdroje v prvom dieli tejto série.
Nevytváral som príklad pre každý úkon, napr. nastavenie primárneho kľúča, ale zakaždým jeden komplexný príklad, ktorý je dobre okomentovaný. Takže poďme na to ;-)
Ak označíme niektorý stĺpec ako primárny kľuč, znamená to, že hodnoty v tomto stĺpci musia byť jedinečné (ak sa pokúsite vložiť opakovanú hodnotu, vznikne výnimka) a bude nám umožnené vyhľadávať riadky na základe tohto stĺpca.
Vizuálne je to veľmi jednoduché: ľavý klik na vybraný stĺpec a vyberte Set Primay Key.
Ak chcete označiť aj iné stĺpce ako kľúče (už samozrejme nie primárne) : ľavý klik na tabuľku -> Add Key -> Zobrazí sa vám tabuľka so všetkými stĺpcami v tabuľke a odpovedajúce checkBoxy, ktoré stačí označiť.
Na nastavenie vzťahov medzi tabuľkami stačí ľavý klik kdekoľvek v Dizajnéri a vybrať Add-> Relation. A možete nastaviť jednotlivé parametre vzťahu podobne ako na obrázku nižšie.
Napr. UpdateRule nastavený na Cascade znamená, že keď niečo vložíte do tabuľky potomka a nie je to v predkovi, tak sa to tam automaticky doplní. Ak je Delete rule nastavené na None, znamená to, že ak sa pokúsite vymazať záznam v predkovi, neumožní Vám to, pokiaľ nejaký záznam v potomkovi ešte naň ukazuje. Tak isto by tu bolo možné nastaviť parameter Cascade.
>>Vyhľadávanie v DataSete
Ja som zatiaľ našiel 4 spôsoby ako nájsť určitý záznam v DataSete, ak poznáte aj ďalší, napíšte kľudne do diskusie.
1. v cykle prechádzať riadok po riadku a porovnávať s hľadanou hodnotou vo vybranom stĺpci.
2. Ak je stĺpec označený ako primárny kľúč, môžeme použiť metódu Find(object o)
3. Ak je DataSet navrhnutý vizuálne a stĺpec je označený ako kľúč, môžeme použiť automaticky vygenerované metódy FindBy...nazovStĺpca.
4. Pomocou kritéria podobnému príkazu SQL, použitím metódy Select(....)
>>Práca s DateSetom,ktorý je navrhnutý vizuálne.
Použijeme 2 tabuľky Vyrobok a Výrobca v DateSete Tovar. Ktoré majú medzi sebou nastavenú závislosť, viď predchádzajúci obrázok.
Poďme hneď na príklad, je podrobne okomentovaní, takže k nemu netreba veľké rozpisovanie.
Myslím, že fakt nie je čo dodať Jeden príklad hovorí za 1000 slov :-)
Snáď si ešte môžeme pozrieť, čo je obsahom takto vygenerovaného XML uloženého v db.xml
>>Práca s DateSetom, ktorý je z časti vytvorený manuálne.
Ak sa primárny kľuč alebo vzťahy medzi tabuľkami nastavujú programovo, je aj práca s DataSetom trochu rozdielna. Aby ste to jednoducho mohli posúdiť sami, urobil som presne ten istý príklad ako je ten predchádzajúci. Štruktúra DataSetu je rovnaká a nastavená vizuálne ale ostane veci už programovo.
Príklad 3.5.2
using System;Všimnite si hlavne spôsob nastavenia properties PrimaryKey, že je to vlastne iba povyberané pole stĺpcov z tabuľky, ktoré chceme označiť ako kľúče.
Potom ForeignKeyConstraint sa vytvoril zviazaním stĺpca z tabuľky predka a stĺpca z tabuľky potomka, nastavil sa mu parameter pre automatické updatovanie aj v nadradených tabuľkách, teda to isté ako sa dalo vizuálne naklikať.
Jeden z rozdielov je pri vkladaní nových záznamov, kde pribudlo napr. ["meno"].ToString());,
Výstupný XML súbor je samozrejme identický ako v predchádzajúcom príklade.
>>Čo bude nabudúce?
Dúfam, že príklady sa Vám hodia, chcel som aby boli maximálne jednoduché a keď si napr. nebudete vedieť presne spomenúť ako sa vyhľadáva v DataSete, vite kde je nájdete tento článok a len pozriete a viete ;-)
Predpokladám, že nasledujúci diel bude posledný z kapitoly o DataSete. Závisí aj od toho, čo sa budete pýtať v diskusii k tomuto článku + vyberiem niektoré užitočné a teda hlavne praktické vlastnosti DataSetu.
[Príklady z článku]
Internetové rádio, pre .NET developerov, vysiela len v určitú dobu.
[Predchádzajúce diely]
Copyright © 2002 - 2013 inet.sk, s. r. o. | Všetky práva vyhradené | Neprešlo jazykovou úpravou | ISSN 1336-1899
Využívame kvalitný webhosting za rozumnú cenu od Inet.sk