Jak tedy zálohovat data v MySQL? Pomocí příkazu SELECT!
6.1.2006 06:00 | Petr Zajíc | přečteno 26332×
Pojďme se dnes podívat na to, jak jednoduše se pomocí MySQL dají
zálohovat data z jedné nebo více tabulek. Jak uvidíte, může s tím být
docela zábava. Již minule jsme hovořili o tom, že jednotlivé metody
zálohování se mohou lišit - dnes uvidíte, že je to skutečně pravda, i
když budeme mluvit jen o jedné z nich.
Klasický příkaz SELECT obsahuje velmi milé rozšíření, které nám umožní přímo vyexportovat vybraná data do textového souboru. Místo toho, abyste napsali příkaz ve stylu:
select * from lidi;
napíšete prostě
select * from lidi into outfile 'lidi.txt';
a výsledná množina dat se vloží do nového souboru. Je to velmi
jednoduchá a prostá myšlenka, která nevyžaduje další znalosti. Stačí
umět používat příkaz SELECT.
Výhod tohoto přístupu k zálohování je
několik, pojďme si projít ty hlavní:
Export můžete jemně ovlivnit použitím několika voleb, které
formátují výstup. Uvádím je v tabulce:
Volba |
Význam |
FIELDS ESCAPED BY |
Escapování znaků. Například NULL
je zapsáno jako \N, pokud je escape znakem obrácené lomítko |
FIELDS ENCLOSED BY |
Umožňuje zvolit znak, který bude
uzavírat data (např. uvozovka) |
FIELDS OPTIONALLY ENCLOSED BY |
Umožňuje zvolit znak, který bude
uzavírat data (např. uvozovka), ovšem pouze textová. Čísla zůstanou
neobklopena ;-) |
FIELDS TERMINATED BY |
Znak sloužící k oddělení polí,
typicky středník nebo tabelátor. |
LINES TERMINATED BY |
Znak sloužící k oddělení řádků
(záznamů). Typicky systémový znak konce řádku. |
Pokud si nechcete tyto volby pamatovat, pak vězte, že nemusíte. K
prostému zazálohování postačí výchozí hodnoty všech voleb. Zejména,
pokud budete chtít data opět obnovit pomocí nástrojů MySQL. Je ale
dobré vědět o těchto přepínačích; zejména pracujete-li pod více
operačními
systémy. Ve Windows je například dobré definovat konec řádku jako \r\n,
aby byl výsledný soubor vidět v textových editorech, které jsou tam k
dispozici.
Pozn.: Nic Vám samozřejmě nebrání
zálohovat data v jednom operačním systému a obnovit je v jiném.
Komplementární příkaz LOAD DATA INFILE má k dispozici volby, pomocí
nichž se vyrovná třeba s nesystémovými oddělovači řádků.
Jak asi tušíte, příkaz SELECT INTO OUTFILE má rovněž nějaké ty nevýhody. Jednou drobnou nevýhodou může být fakt, že textový soubor po vytvoření neobsahuje záhlaví sloupců. To je sice možná trochu nepříjemné, ale nikoli neřešitelné. Můžete totiž exportní příkaz upravit ve smyslu:
select 'jmeno','narozen
dne' union all select jmeno, narozendne from lidi into outfile
'lidi2.txt';
Připomeňme, že příkaz UNION
umožňuje spojit data z více tabulek. V našem případě byla první
"tabulka" jen virtuální a obsahovala názvy polí. MySQL přitom ani
nevadí, že spojovaná data nejsou téhož typu, takže tento příkaz můžete
bez obav použít. Další drobnou nevýhodou příkazu je fakt, že se nedá
přesně určit, kam budou data zapsána v případě, že neuvedete absolutní
cestu. Mám zkušenost, že to závisí na verzi MySQL a na používané
distribuci, takže je třeba být opatrný, pokud se chcete na výchozí
chování systému spolehnout. Já bych preferoval jistější způsob - a to
vždy uvádět absolutní cestu k exportovanému souboru.
A teď ty největší nevýhody. Všechny podstatné nějakým způsobem
souvisejí se
zabezpečením.
K databázovým právům - MySQL kontroluje, kdo smí nebo nesmí v operačním systému vytvářet soubory. Což se přesně týká příkazu SELECT INTO OUTFILE. Pokud budete chtít zjistit aktuální stav oprávnění pro zápis do souborů, můžete to provést dotazem na metadata (od verze 5.0) nějak takto:
select * from
user_privileges where privilege_type = 'FILE';
Špatná zpráva pro uživatele MySQL na hostinzích je ta, že většinou
mít potřebná práva nebudete -
a to je docela škoda. Tento způsob zálohování patří totiž k těm
rychlejším a pružnějším. Ale pokračujme ještě dalšími omezeními:
Pokud máte přístup k systému, na němž MySQL běží a pokud se chcete zabývat zálohováním jen nějakých dat, pak je pro Vás jistě SELECT INTO OUTFILE dobrou volbou. V opačném případě však nejspíš kvůli bezpečnostním omezením systému nebudete moci tento přístup použít a je potřeba jít na to jinak. Jak, to uvidíme v dalším díle našeho seriálu.