MySQL (57) - Ach, ta čeština
Podle mě musí existovat spojení mezi slovy "konverze" a "kontroverze". Máloco je totiž ve spojení s MySQL tak časté, jako dotazy ohledně češtiny a znakových sad vůbec. Rozeberme to.
3.2.2006 06:00 |
Petr Zajíc
| Články autora
| přečteno 28539×
Dozrál čas věnovat se dotazům, které se v té či oné formě pravidleně
objevují v mojí e-mailové schránce a které se v souvislosti s MySQL tak
či onak dotýkají znakových sad. Naše požehnaná mateřština disponuje
celou řadou hlásek s háčky a čárkami, což programátorovi a správci
databáze může pěkně zatopit. Postupně si ukážeme, že porozumět tomu,
jak se chová MySQL v takových situacích není zase až tak složité, pokud
člověk vezme v úvahu všechny faktory. Leč postupně, nejprve trocha té
nezbytné teorie.
MySQL, znakové sady a potíže s nimi
Řetězce v databázi mohou být uloženy v mnoha znakových sadách. MySQL
tento pohled na věc velmi dobře podporuje. Znaková sada zde může být
specifikována pro celý server, pro jednu databázi, pro jednu tabulku
nebo dokonce pro jediný sloupec. Nicméně je třeba pochopit
celý mechanismus a správně ho uplatnit, aby to všechno fungovalo k naší
spokojenosti. Kdy se
vlastně v souvislosti s MySQL a řetězci musíme zajímat o znakové sady?
V několika hlavních situacích:
- Při importu dat do databáze nebo při ukládání znakových dat
sesbíraných pomocí nějaké klientské aplikace
- Při interní manipulaci s řetězci uvnitř MySQL
- Při zobrazení dat "vně" databáze, prostě když je chceme vydolovat
a použít
Lehce si to celé rozeberme, abychom pochopili, jak to všechno
souvisí. Platí totiž zásada, že buď:
- je dobré při manipulaci se znakovými sadami vybrat si jednu a té
se držet, nebo
- používat několik znakových sad a na správném místě provést
konverzi mezi nimi pomocí nástrojů, které poskytuje MySQL nebo
podkladový operační systém
Pozn.: Pro mě je "správný" ten první
postup. Ke konverzím se uchyluji jen když je to nezbytné, třeba když
musím spolupracovat s více oddělenými systémy s jiným kódováním.
Import nebo vstup dat
Nezřídka je nutné importovat data do MySQL z externích zdrojů, jak
jsme o tom psali minule. Například pokud se jedná o import textových
souborů - jsou uloženy ve správné znakové sadě? Pokud vaše distribuce
používá UTF-8, pak budou textová data nejspíš v tomto kódování. Pokud
máte něco jiného (jako je soubor pocházející z Windows), bude třeba
na to myslet již před importem.
Pozn.: Situace, kdy se naimportují data
v neodpovídající znakové sadě je zejména u začátečníků poměrně častá.
Obyčejně je mnohem účinnější provést import znovu, než se snažit o
opravu existujících dat uvitř databáze.
Manipulace s daty
Třebaže se to nezdá, je i tady zapotřebí mít se na pozoru. Především
je MySQL hodně flexibilní, takže v jedné databázi, i dokonce v jediné
tabulkce můžete mít data v několika znakových sadách. Takže, příkaz
INSERT nebo UPDATE může s nabodeníčky krásně zamíchat, pokud si na to
nedáte pozor. Další často opomíjenou skutečností je fakt, že v určitém
kódování funguje rovněž klient, kterého používáte (jako je řádkový
klient nebo PHPMyAdmin). Pokyny, které databáze dostane tedy musejí
přijít se správnou diakritikou, aby to celé mohlo smysluplně pracovat.
Hezky je to vidět na příkazech SELECT:
select * from pracovnik
where prijmeni = 'Žežulka' and obec = 'Středoplky'
To může být sice napsáno správně, a v databázi mohou odpovídající
záznamy existovat, přesto však někdy nedostaneme to, co potřebujeme.
Důvodem může být nešťastná konverze, kterou klient provede předtím, než
databáze pokyn obdrží. Může vzniknout jen těžko dohledatelná chyba nebo
mohou být nalezeny záznamy, které jsme nechtěli.
Výstup dat
Vlastně to hezky souvisí s oběma předchozími problémy: Nějaký
konzument dat (desktopová aplikace, webová stránka nebo cokoli jiného)
požaduje znaková data a databáze mu je pošle. Zobrazí se na výstupu to,
co jsme potřebovali? To bude opět záviset na více faktorech. Především
je nutné, aby klient dokázal o data správně požádat, a potom také to,
aby je správně předložil uživateli.
V případě webových aplikací bude nejspíš výstupem nějaká HTML
stránka, která ovšem rovněž používá kódování. Takže, může vzniknout
několik problémů, které spolu souvisejí. Postupně si v tomto seriálu
ukážeme, jak se celý ten zašmodrchanec dá rozplést.
Řazení dat
Abych předešel případným dotazům, řeknu to rovnou: řazení znakových
dat sice souvisí se znakovými sadami, ale není
to totéž. V databázi můžeme například mít znaková data v UTF-8 a
požadujeme jejich české řazení, stejně tak ale pro UTF-8 data můžeme
chtít řazení anglické nebo německé. Tomuto tématu se budeme věnovat
později, teď jen zásada: Nastavení znakové sady pro databázi není totéž
co nastavení způsobu řazení dat.
Lehký úvod do problematiky
Jak vidíte, je toho dost a jistě nám tato látka vystačí na více dílů
seriálu. Obecně lze říci, že MySQL podporuje více znakových sad,
přičemž záleží na nastavení při kompilaci, které budou k dispozici.
Seznam dostupných znakových sad můžete zobrazit příkazem
SHOW CHARACTER SET;
a seznam dostupných řazení pak pomocí příkazu
SHOW COLLATION;
Pozn.: Nelekněte se. Moje výchozí
instalace MySQL "pětky" obsahuje 36 znakových sad a 124 vestavěných
způsobů řazení dat, takže je toho opravdu dost. V praxi však budete
používat většinou jen zlomek toho, co je ve skutečnosti k dispozici.
My se příště podíváme na praktický příklad, jak se se znakovými
sadami vypořádat v situacích, které jsem nastínil. Dopředu prozradím,
že budu doporučovat používání UTF-8 podobně, jako to děláme tady na
serveru při psaní stránek. Rovněž naznačím, co Vás může potkat za
problémy a jak se s nimi vypořádat; a pokusím se zodpovědět nejčastější
dotazy, které mi v té souvislosti chodí.
A ještě něco: Příště udělám trochu ústupek a použiju příklady psané
v PHP, přestože jsem si předsevzal, že se v tomto seriálu budu snažit
věnovat pouze databázi bez vazby na konkrétní programovací jazyky.
Důvod je prostý - většina lidí takto MySQL používá a problémy se mohou
prolínat, takže zahrnu do vysvětlování i PHP.
Verze pro tisk
|
Nejsou žádné diskuzní příspěvky u dané položky.
Příspívat do diskuze mohou pouze registrovaní uživatelé.
|
|

Vyhledávání software

Vyhledávání článků
28.11.2018 23:56 /František Kučera Prosincový sraz spolku OpenAlt se koná ve středu 5.12.2018 od 16:00 na adrese Zikova 1903/4, Praha 6. Tentokrát navštívíme organizaci CESNET. Na programu jsou dvě přednášky: Distribuované úložiště Ceph (Michal Strnad) a Plně šifrovaný disk na moderním systému (Ondřej Caletka). Následně se přesuneme do některé z nedalekých restaurací, kde budeme pokračovat v diskusi.
Komentářů: 1
12.11.2018 21:28 /Redakce Linuxsoft.cz 22. listopadu 2018 se koná v Praze na Karlově náměstí již pátý ročník konference s tématem Datová centra pro business, která nabídne odpovědi na aktuální a často řešené otázky: Jaké jsou aktuální trendy v oblasti datových center a jak je optimálně využít pro vlastní prospěch? Jak si zajistit odpovídající služby datových center? Podle jakých kritérií vybírat dodavatele služeb? Jak volit vhodné součásti infrastruktury při budování či rozšiřování vlastního datového centra? Jak efektivně datové centrum spravovat? Jak co nejlépe eliminovat možná rizika? apod. Příznivci LinuxSoftu mohou při registraci uplatnit kód LIN350, který jim přinese zvýhodněné vstupné s 50% slevou.
Přidat komentář
6.11.2018 2:04 /František Kučera Říjnový pražský sraz spolku OpenAlt se koná v listopadu – již tento čtvrtek – 8. 11. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma umění a technologie, IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
4.10.2018 21:30 /Ondřej Čečák LinuxDays 2018 již tento víkend, registrace je otevřená.
Přidat komentář
18.9.2018 23:30 /František Kučera Zářijový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 20. 9. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
9.9.2018 14:15 /Redakce Linuxsoft.cz 20.9.2018 proběhne v pražském Kongresovém centru Vavruška konference Mobilní řešení pro business.
Návštěvníci si vyslechnou mimo jiné přednášky na témata: Nejdůležitější aktuální trendy v oblasti mobilních technologií, správa a zabezpečení mobilních zařízení ve firmách, jak mobilně přistupovat k informačnímu systému firmy, kdy se vyplatí používat odolná mobilní zařízení nebo jak zabezpečit mobilní komunikaci.
Přidat komentář
12.8.2018 16:58 /František Kučera Srpnový pražský sraz spolku OpenAlt se koná ve čtvrtek – 16. 8. 2018 od 19:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát jsou tématem srazu databáze prezentaci svého projektu si pro nás připravil Standa Dzik. Dále bude prostor, abychom probrali nápady na využití IoT a sítě The Things Network, případně další témata.
Přidat komentář
16.7.2018 1:05 /František Kučera Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.
Přidat komentář
Více ...
Přidat zprávičku
 Poslední diskuze
31.7.2023 14:13 /
Linda Graham iPhone Services
30.11.2022 9:32 /
Kyle McDermott Hosting download unavailable
13.12.2018 10:57 /
Jan Mareš Re: zavináč
2.12.2018 23:56 /
František Kučera Sraz
5.10.2018 17:12 /
Jakub Kuljovsky Re: Jaký kurz a software by jste doporučili pro začínajcího kodéra?
Více ...
|