LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> MySQL (12) - tipy k tvorbě tabulek

MySQL, tabulky a speciality - automaticky číslovaná pole, dočasné tabulky a tak dále.

12.4.2005 12:00 | Petr Zajíc | Články autora | přečteno 49099×

Stejně, jako je tomu v kterémkoli zákoutí práce s počítačem, má i tvorba tabulek v databázích svoji "třináctou komnatu". Proto se dnes podíváme na některé podrobnosti práce s tabulkami, které se vám v praxi mohou velmi hodit.

Seznam tabulek

MySQL, stejně jako prakticky každá jiná databáze, má příkaz, kterým zobrazíte seznam existujících tabulek v databázi. Provedete to pomocí tohoto kódu:

SHOW TABLES;

Aby to fungovalo, musíte mít zvolenu nějakou databázi. Jinými slovy, bezprostředně po přihlášení k serveru, pokud nepoužijete příkaz USE [název databáze], tak to selže. Příkaz SHOW TABLES má ovšem určité rozšíření, které trochu popírá předchozí větu - ono to totiž jde napsat takto:

SHOW TABLES FROM SHOP;

A pak je samozřejmě úplně jedno, v jaké databázi jsme, protože budou vypsány tabulky ze zvolené databáze.

Pozn.: Seznam tabulek v nějaké databázi je typickým příkladem toho, čemu se říká metadata, neboli "data o datech". Pokud se budete věnovat databázím hlouběji, zjistíte, že porozumět metadatům a umět s nimi pracovat je docela důležité. Například v úlohách typu import - export dat a podobně.

Dočasné tabulky

Dočasné tabulky se od "trvalých" tabulek liší především tím, že existují pouze od jejich vytvoření do ukončení spojení, které je má "na svědomí". Tedy - jakmile zanikne připojení, zaniknou i všechny dočasné tabulky, které během tohoto spojení vznikly. Vytvořit dočasnou tabulku přitom není nikterak složité. Stačí zavzpomínat na minulý díl a doplnit, že při manipulaci s dočasnými tabulky se mezi CREATE a TABLE vloží klíčové slovo TEMPORARY:

CREATE TEMPORARY TABLE PENIZE (MNOZSTVI int);

Většina z toho, co platí o normálních tabulkách, platí i o tabulkách dočasných. To například znamená, že můžete použít rozšíření IF NOT EXISTS, jak o něm byla řeč v minulém díle. Stejně tak lze vytvořit dočasnou tabulku kopírováním existující (a to jak dočasné, tak trvalé) tabulky nějak takto:

CREATE TEMPORARY TABLE PENIZE2 LIKE PENIZE;

Ovšem, používání dočasných tabulek má rovněž svoje záludnosti. O nich byste měli něco vědět, pokud je chcete používat. Tak především, narozdíl od trvalých tabulek mohou dvě různá připojení vytvořit dvě dočasné tabulky se stejným názvem (aniž by to kolidovalo). To je celkem příjemné. Vyplývá z toho, že pokud víte, že jste určitě nevytvářeli dočasnou tabulku nějakého jména, prakticky nikdy nemusíte používat klauzuli IF NOT EXISTS. Další věc - dočasné tabulky se neobjevují ve výpise tabulek pořízeného pomocí příkazu SHOW TABLES. A nakonec, manuál tvrdí, že mohou existovat další omezení.

Proč by mohl někdo chtít používat dočasné tabulky? V praxi je používám ve třech případech:

  1. Někdy existuje výpočet, který je tak složitý nebo natolik náročný na zdroje, že je rozumné nějak ukládat mezivýsledky. V takovém případě může být použití dočasné tabulky docela na místě.
  2. Někdy bývá třeba pracovat s určitou podmnožinou dat z rozsáhlé tabulky, nebo dokonce s podmnožinou dat z více velkých tabulek (mám na mysli tabulky s desetitisíci nebo statisíci záznamy). V takovém případě může být praktické vykopírovat si onu podmnožinu dat do dočasné tabulky a pak tuto tabulku použít.
  3. Někdy je potřeba opakovaně použít data vzniklá nějakým výpočtem. Dočasná tabulka může v takovém případě být to "pravé ořechové".

Pozn.: Uvedené zásady byste něměli chápat jako definitivní. Existuje totiž celá řada dalších mechanizmů, které řeší některé z problémů popsaných výše (indexy, pohledy atd.). Chtěl jsem jen, abyste měli představu, k čemu se dočasné tabulky dají použít.

Automaticky číslovaná pole

V tabulkách bývá, a to velmi často, pole jednoznačně identifikující daný řádek. V různých DBMS se vytvářejí různě, většinou jako náhodná čísla nebo sekvence. Typické je, že existuje pole, které automaticky s každým přidaným řádkem zvýší čítač o jedničku. MySQL má podporu pro tuto funkci. Ačkoli to souvisí s indexy, o nichž teprve v seriálu bude řeč, již teď vám ukážu, jak se automaticky číslované pole vytvoří:

CREATE TABLE cislovani (id INT AUTO_INCREMENT, PRIMARY KEY (id));

K tomu si dovolím několik postřehů:

  • Automaticky číslované pole se většinou označuje tak, aby z názvu bylo poznat, že se jedná o takové pole. Typicky ID (identity), nebo [název tabulky]ID a podobně.
  • Jak později v seriálu uvidíme, automaticky číslovaná pole musejí být součástí indexu. Uvidíme také, že toto omezení má logický důvod.
  • Třebaže většinou necháme číslování řádků na aplikaci, principelně nic nebrání vložení hodnoty do tohoto pole přímo (tzn. vložení například čísla 15 projde, přestože nejvyšší dosud vložené číslo nebyla 14. Vložení pochopitelně selže, pokud by tam patnáctka již byla).
  • MySQL nevyplňuje "díry" vzniklé odstraněním řádků (nebo vložením jiné než následující hodnoty v řadě). Je-li záznam smazán, jeho automatické číslo již nikdy nebude přiděleno.
  • V jedné tabulce smí být nejvýše jedno automatické číslování.
  • Pokud by při číslování měl být překročen maximální rozsah hodnot, které lze do číslovacího sloupce vložit, dojde k chybě, a řádek nebude vložen.
  • Automaticky číslované pole lze přidat k již existující tabulce. MySQL pochopitelně doplní čísla, pokud by snad tabulka již obsahovala nějaká data.

Automatická čísla se v tabulkách MySQL používají velmi často. Je to jednoduše řečeno proto, že prakticky v každé tabulce existuje důvod mít jednoznačně identifikované řádky.

Přejmenování tabulky

V MySQL existuje možnost přejmenovat existující tabulku, a to beze ztráty dat. Slouží k tomu příkaz rename table:

RENAME TABLE cislovani TO cislovani2;

Ačkoli je to jednoduché, existuje dost dobrých důvodů, proč to NEDĚLAT. Níže uvádím ty nejpodstatnější:

  • Nutnost přejmenovat tabulku obvykle poukazuje na to, že programátor nemá propracovanou metodiku názvu objektů, nebo že ji má "děravou".
  • Přejmenováním tabulky se automaticky NEUPRAVÍ všechny příkazy, v nichž tabulka byla použita. Znamená to, že může přestat bez varování fungovat nějaký kód. Zejména to platí o MySQL 5.x, kde je možno používat uložené procedury.
  • Je třeba si uvědomit, že jedna nebo i více klientských aplikací může mít starý název tabulky někde ve zdrojovém kódu. Je třeba to zkontrolovat a opravit i tam.

Tip: V naprosté většině editorů zdrojového kódu lze použít příkazy pro vyhledání a nahrazení, takže to nemusí být až takový problém. Pokud jde o příkazy uložené v databázi, existuje postup, při němž se 1) databáze oskriptuje, 2) ve vzniklém scriptu se vyhledají všechny zmínky o původním názvu tabulky a 3) ty se opraví. Nicméně, přejmenování tabulky dost často vede ke komplikacím, zejména pokud je projekt již v pokročilém stádiu vývoje.

V dalším díle seriálu se podíváme na to, jak do tabulek v MySQL vkládat data.

Verze pro tisk

pridej.cz

 

DISKUZE

automaticke cislovani 27.4.2005 09:49 Karel Honzl
  L Re: automaticke cislovani 28.4.2005 17:30 Petr Zajíc




Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

14.11.2017 16:56 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě DIY, CNC, SDR nebo morseovka? Přijď na sraz spolku OpenAlt – tradičně první čtvrtek před třetím pátkem v měsíci: 16. listopadu od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

12.11.2017 11:06 /Redakce Linuxsoft.cz
PR: 4. ročník odborné IT konference na téma Datová centra pro business proběhne již ve čtvrtek 23. listopadu 2017 v konferenčním centru Vavruška, v paláci Charitas, Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00. Konference o návrhu, budování, správě a efektivním využívání datových center nabídne odpovědi na aktuální a často řešené otázky, např Jaké jsou aktuální trendy v oblasti datových center a jak je využít pro vlastní prospěch? Jak zajistit pro firmu či jinou organizaci odpovídající služby datových center? Podle jakých kritérií vybrat dodavatele služeb? Jak volit součásti infrastruktury při budování či rozšiřování vlastního datového centra? Jak efektivně spravovat datové centrum? Jak eliminovat možná rizika? apod.
Přidat komentář

13.9.2017 8:00 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě DIY, CNC, SDR nebo morseovka? Přijď na sraz spolku OpenAlt – tentokrát netradičně v pondělí: 18. září od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

3.9.2017 20:45 /Redakce Linuxsoft.cz
PR: Dne 21. září 2017 proběhne v Praze konference "Mobilní řešení pro business". Hlavní tématy konference budou: nejnovější trendy v oblasti mobilních řešení pro firmy, efektivní využití mobilních zařízení, bezpečnostní rizika a řešení pro jejich omezení, správa mobilních zařízení ve firmách a další.
Přidat komentář

15.5.2017 23:50 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě DIY, CNC, SDR nebo morseovka? Přijď na sraz spolku OpenAlt, který se bude konat ve čtvrtek 18. května od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

12.5.2017 16:42 /Honza Javorek
PyCon CZ, česká konference o programovacím jazyce Python, se po dvou úspěšných ročnících v Brně bude letos konat v Praze, a to 8. až 10. června. Na konferenci letos zavítá např. i Armin Ronacher, známý především jako autor frameworku Flask, šablon Jinja2/Twig, a dalších projektů. Těšit se můžete na přednášky o datové analytice, tvorbě webu, testování, tvorbě API, učení a mentorování programování, přednášky o rozvoji komunity, o použití Pythonu ve vědě nebo k ovládání nejrůznějších zařízení (MicroPython). Na vlastní prsty si můžete na workshopech vyzkoušet postavit Pythonem ovládaného robota, naučit se učit šestileté děti programovat, efektivně testovat nebo si v Pythonu pohrát s kartografickým materiálem. Kupujte lístky, dokud jsou.
Přidat komentář

2.5.2017 9:20 /Eva Rázgová
Putovní konference československé Drupal komunity "DrupalCamp Československo" se tentokrát koná 27. 5.2017 na VUT FIT v Brně. Můžete načerpat a vyměnit si zkušenosti z oblasti Drupalu 7 a 8, UX, SEO, managementu týmového vývoje, využití Dockeru pro Drupal a dalších. Vítáni jsou nováčci i experti. Akci pořádají Slovenská Drupal Asociácia a česká Asociace pro Drupal. Registrace na webu .
Přidat komentář

1.5.2017 20:31 /Pavel `Goldenfish' Kysilka
PR: 25.5.2017 proběhne v Praze konference na téma Firemní informační systémy. Hlavními tématy jsou: Informační systémy s vlastní inteligencí, efektivní práce s dokumenty, mobilní přístup k datům nebo využívání cloudu.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

15.12.2017 15:11 / Petit
freehold nj

15.12.2017 15:06 / Petit
nj freehold

5.12.2017 11:50 / Thomas
kitchen renovations

18.9.2017 14:37 / Rojas
high security vault

15.9.2017 7:33 / Wilson
new zealand childcare jobs

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2017) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze