MySQL: Porovnání verzí
úprava aktuální verze značka: editace z Vizuálního editoru |
|||
(Není zobrazeno 39 mezilehlých verzí od 27 dalších uživatelů.) | |||
Řádek 1: | Řádek 1: | ||
{{Infobox - software |
{{Infobox - software |
||
| jméno = MySQL |
|||
| logo = |
|||
| velikost loga = |
|||
| obrázek = Mysql-screenshot.PNG |
|||
| velikost obrázku = |
|||
| alt = |
|||
| popisek = [[Snímek obrazovky|Snímek]] příkazové řádky MySQL |
|||
| vývojář = [[Oracle Corporation]] |
|||
| první vydání = [[23. květen|23. května]] [[1995]] |
|||
| aktuální verze = 5.6.21<ref>{{cite web |url=http://dev.mysql.com/doc/relnotes/mysql/5.6/en/news-5-6-21.html |title=Změny v MySQL 5.6.21|date=23. září |work=MySQL 5.6 Reference Manual |publisher=[[Oracle Corporation|Oracle]] |accessdate=23 September 2014}}</ref> |
|||
| aktuální verze = 8.3.0<ref>{{Citace elektronické monografie | url =https://dev.mysql.com/doc/refman/8.3/en/mysql-nutshell.html | titul = Changes in MySQL 8.3.0 | datum = 2024-01-16 | vydavatel = mysql.com | datum přístupu = 2024-01-30 | jazyk = anglicky}}</ref> |
|||
| datum aktuální verze = [[16. leden|16. ledna]] [[2024]] |
|||
| připravovaná verze = 5.7.4 |
|||
⚫ | |||
| datum připravované verze = [[31. březen]] [[2014]] |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
| licence = [[GNU General Public License|GPL]] (verze 2) nebo [[Komerční software|komerční]]<ref>{{Citace elektronické monografie | url = http://www.mysql.com/downloads | titul = Downloads | vydavatel = MySQL | datum = | datum_přístupu = 2014-08-03}}</ref> |
|||
⚫ | |||
⚫ | |||
| licence = [[GNU General Public License|GPL]] nebo [[Komerční software|komerční]] |
|||
⚫ | |||
⚫ | |||
⚫ | |||
}} |
}} |
||
⚫ | '''MySQL''' je [[Otevřený software|otevřený]] [[systém řízení báze dat]] uplatňující [[Relační model|relační databázový model]], vytvořený [[švédsko]]u firmou [[MySQL AB]], nyní vlastněný společností [[Oracle Corporation]]. Jeho hlavními autory jsou [[Michael Widenius|Michael „Monty“ Widenius]] a [[David Axmark]]. Je považován za úspěšného průkopníka dvojího licencování – je k dispozici jako [[Svobodný a otevřený software|svobodný a otevřený sofware]] pod bezplatnou licencí [[GNU General Public License|GPL]], tak pod řadou komerčních placených licencí. |
||
⚫ | |||
⚫ | '''MySQL''' je [[ |
||
⚫ | Pro svou snadnou implementovatelnost (lze jej instalovat na [[Linux|GNU/Linux]], [[Microsoft Windows|MS Windows]], ale i další operační systémy), výkon a především díky tomu, že se jedná o volně šiřitelný software, má vysoký podíl na v současné době používaných databázích. Velmi oblíbená a často nasazovaná je kombinace GNU/Linux, [[Apache HTTP Server|Apache]], MySQL a programovacího jazyka [[PHP]], jako základní software webového serveru („technologie [[LAMP]]“). |
||
⚫ | |||
⚫ | MySQL bylo od počátku optimalizováno především na rychlost, a to i za cenu některých zjednodušení: má jen jednoduché způsoby zálohování; od roku 2005 podporuje i tzv. [[Pohled (databáze)|pohledy]], [[trigger (databáze)|triggery]], a [[uložená procedura|uložené procedury]].<ref>{{Citace elektronického periodika |
||
⚫ | Pro svou snadnou implementovatelnost (lze jej instalovat na [[Linux]], [[Microsoft Windows|MS Windows]], ale i další operační systémy), výkon a především díky tomu, že se jedná o |
||
| titul = ABIS Infor - MySQL: stored procedures and SQL/PSM |
|||
| periodikum = www.abis.be |
|||
⚫ | MySQL bylo od počátku optimalizováno především na rychlost, a to i za cenu některých zjednodušení: má jen jednoduché způsoby zálohování |
||
| url = https://www.abis.be/html/en2012-10_MySQL_procedures.html |
|||
| datum přístupu = 2020-04-11 |
|||
}}</ref> |
|||
== Architektura MySQL serveru == |
== Architektura MySQL serveru == |
||
[[Soubor: |
[[Soubor:Mysql architekture schema.png|náhled|Architektura MySQL serveru]] |
||
Architektura MySQL se velmi odlišuje od architektur jiných databázových serverů, má široký záběr a je užitečná pro řešení mnoha různorodých úloh. |
Architektura MySQL se velmi odlišuje od architektur jiných databázových serverů, má široký záběr a je užitečná pro řešení mnoha různorodých úloh. Nejsvrchnější vrstva obsahuje služby, jež nejsou jedinečné pro MySQL. Obsluhují většinu potřebných nástrojů klient/server, které jsou založeny na síti. |
||
Ve druhé vrstvě se nachází valná část mozku MySQL, včetně kódu pro rozbor (parsing), analýzu, optimalizaci a pro všechny zabudované funkce. Na této úrovni se nachází veškerá funkcionalita, která se poskytuje prostřednictvím úložných enginů. |
Ve druhé vrstvě se nachází valná část mozku MySQL, včetně kódu pro rozbor (parsing), analýzu, optimalizaci a pro všechny zabudované funkce. Na této úrovni se nachází veškerá funkcionalita, která se poskytuje prostřednictvím úložných enginů. |
||
Třetí vrstva obsahuje úložné enginy. Ty mají na starosti ukládání a získávání všech dat uložených v |
Třetí vrstva obsahuje úložné enginy. Ty mají na starosti ukládání a získávání všech dat uložených v MySQL. Server komunikuje s úložnými enginy prostřednictvím [[API]] úložných enginů. Toto rozhraní skrývá rozdíly mezi jednotlivými úložnými enginy a činí je na vrstvě dotazů velmi transparentními. [[API]] obsahuje několik desítek nízkoúrovňových funkcí, které provádějí operace jako „zahájit transakci“ nebo „získat řádek, který má tento primární klíč“. Úložné enginy nedělají rozbor [[SQL]] a nekomunikují mezi sebou – jednoduše pouze odpovídají na požadavky serveru. |
||
=== Správa připojení a bezpečnost === |
=== Správa připojení a bezpečnost === |
||
Každé klientské připojení dostane uvnitř serverového procesu vlastní vlákno (thread). Dotazy tohoto připojení se vykonávají uvnitř tohoto jediného vlákna, které zase sídlí na jednom jádru nebo [[ |
Každé klientské připojení dostane uvnitř serverového procesu vlastní vlákno (thread). Dotazy tohoto připojení se vykonávají uvnitř tohoto jediného vlákna, které zase sídlí na jednom jádru nebo [[Centrální procesorová jednotka|CPU]]. Protože server udržuje vlákna v [[cache]], nemusejí se vytvářet a likvidovat pro každé nové připojení. [[Autentizace]] je založena na uživatelském jménu, hostiteli, odkud pocházejí a heslu. Dají se také používat certifikáty [[X509]] přes připojení [[SSL]]. Jakmile se klient připojí, server pro každý dotaz vydaný klientem ověřuje, zdali má patřičná oprávnění pro akci, kterou chce vykonat. |
||
=== Optimalizace a vykonávání === |
=== Optimalizace a vykonávání === |
||
MySQL provádí rozbor dotazů proto, aby vytvořil interní stromovou strukturu (parse tree), pak aplikuje všelijaké optimalizace. Může dotaz přepsat, určit pořadí, v |
MySQL provádí rozbor dotazů proto, aby vytvořil interní stromovou strukturu (parse tree), pak aplikuje všelijaké optimalizace. Může dotaz přepsat, určit pořadí, v němž bude číst tabulky, zvolit, které [[Index (databáze)|indexy]] použije atd. Prostřednictvím speciálních klíčových slov může programátor optimalizátoru předat tzv. pokyny, jimiž se dá ovlivnit rozhodovací proces. Optimalizátor se ve skutečnosti nestará o to, který úložný engine používá konkrétní tabulka. Úložný engine ovšem ovlivňuje, jak server optimalizuje dotaz. Optimalizátor od úložného enginu zjišťuje, zdali má jistou výbavu, ptá se na náklady jistých operací a dotazuje se na statistiky o datech tabulky. |
||
Ovšem ještě dřív než server začne s |
Ovšem ještě dřív než server začne s rozborem dotazu, obrátí se na [[cache dotazů]] (query cache), kam může ukládat pouze příkazy pro výběr, [[SELECT]] společně s jejich výslednými sadami. Jestliže někdo vydá dotaz, který je identický s nějakým dotazem, který je už k dispozici v cache, server nemusí dělat vůbec žádný rozbor, nemusí nic optimalizovat a dokonce nemusí dotaz ani vykonat – jednoduše pouze předá zpět uloženou výslednou sadu. |
||
=== Úložné |
=== Úložné databázové stroje (úložiště dat) === |
||
⚫ | |||
⚫ | MySQL ukládá každou databázi (také se jim říká schéma) do podadresáře svého datového adresáře na odkladovém souborovém systému (dá se změnit klauzulí <tt>DATA DIRECTORY</tt> a <tt>INDEX DIRECTORY</tt>). |
||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
* [[FEDERATED]] – umožňuje uživateli vytvořit tabulku, která je lokální reprezentací cizí (vzdálené) tabulky. |
|||
* [[InnoDB]] – stroj navržen pro zpracování transakcí. |
|||
⚫ | |||
⚫ | |||
* [[MyISAM]] – výchozí formát úložiště dat v databázovém systému MySQL, který podporuje [[fulltextové vyhledávání]]. |
|||
⚫ | |||
⚫ | Úložiště fungují jako [[modularita|moduly]], které lze k distribuci tohoto databázového systému doinstalovat; jejich aktuální seznam lze zjistit příkazem <tt>[[SHOW]] ENGINES</tt> nebo <tt>SELECT * FROM information_schema.ENGINES</tt>. Každé úložiště ukládá data tabulky a její případné klíče jinak, definici tabulky ovšem zpracovává samotný server. |
||
=== Ukládání dat === |
|||
⚫ | MySQL ukládá každou databázi (také se jim říká schéma) do podadresáře svého datového adresáře na odkladovém souborovém systému (dá se změnit klauzulí <tt>DATA DIRECTORY</tt> a <tt>INDEX DIRECTORY</tt>). Každá vytvořená tabulka (s výjimkou enginů BLACKHOLE, MEMORY, EXAMPLE) je MySQL uložena do souborů s těmito příponami: |
||
* <tt>.frm</tt> – definice tabulky |
* <tt>.frm</tt> – definice tabulky |
||
* <tt>.MYD</tt> – data tabulky |
* <tt>.MYD</tt> – data tabulky |
||
* <tt>.MYI</tt> – |
* <tt>.MYI</tt> – klíče tabulky |
||
Název souboru bez přípony se shoduje s názvem tabulky. Jelikož MySQL používá při ukládání definic souborový systém, otázka rozlišování velikosti písmen je závislá na platformě. Na instalaci MySQL na [[Microsoft Windows|Windows]] se velikost písmen v názvech tabulek a databází nerozlišuje, na [[unix]]ových systémech se velikost písmen rozlišuje. Každý úložný engine ukládá tabulky a indexy jinak, definici tabulky ovšem zpracovává samotný server. |
|||
==== Závislost na diskovém systému ==== |
|||
⚫ | |||
Na rozdíl od databázových řešení, držící databázi v jednom souboru (MS Access, [[SQLite]]) v MySQL název adresáře odpovídá názvu databáze a název souboru (bez přípony) odpovídá názvu tabulky. Jelikož MySQL používá při ukládání definic souborový systém, otázka rozlišování velikosti písmen je závislá na platformě. Na instalaci MySQL na [[Microsoft Windows|Windows]] se velikost písmen v názvech tabulek a databází nerozlišuje, na [[UN*X|unixových]] systémech se velikost písmen rozlišuje. Databáze i tabulky mohou být pojmenovány téměř libovolně, mohou sestávat jen z číslic, obsahovat mezery, speciální znaky i znaky [[Unicode]] (kromě znaků s kódem 0 a nad 65 535). V MySQL se pak takové jméno uvádí ve zpětných jednoduchých uvozovkách (`) – to platí i v případě, je-li název tabulky/databáze shodný s nějakým z klíčových slov SQL. Identifikátor může dokonce obsahovat i zpětnou uvozovku, v tom případě je tento znak zdvojen. V souborovém systému je pak každý takový znak (tj. každý kromě A–Z, a–z, 0–9 a _) zakódován do sekvence <tt>@</tt> + [[ASCII]] kódu daného znaku (dle UTF-16, uvedeného hexadecimálně jako 4 číslice, doplněném nulami, např. mezera jako <tt>@0020</tt>). MySQL pak interně dělá příslušné konverze při každém přístupu k těmto adresářům a souborům. To, které znaky takto budou zakódovány, je závislé na souborovém resp. operačním systému, stejně jako případné limity v maximální délce názvu souboru či adresáře (podle [http://dev.mysql.com/doc/refman/5.0/en/identifiers.html dokumentace] 64, ale v případě, že každý bude zakódován, to dělá 320 znaků oproti 255 znakům např. v [[NTFS]]), maximálním počtu tabulek v databázi nebo databází v systému a výše zmíněné (ne)rozlišování velikosti písmen. Z tohoto důvodu se nedoporučuje vkládat do názvů databází a tabulek „nekonvenční“ znaky, používat znaky s diakritikou a na [[UN*X|unixových]] systémech (včetně Linuxu) se silně nedoporučuje používat databáze/tabulky nazvané stejně, rozlišené jen velikostí písmen. |
|||
⚫ | |||
⚫ | |||
⚫ | |||
⚫ | |||
* [[FEDERATED]] |
|||
⚫ | |||
⚫ | |||
⚫ | |||
* [[MyISAM]] |
|||
⚫ | |||
Další prvek, který koresponduje s vytvářením souborů na disku, je tzv. partitioning, to jest vnitřní rozdělení tabulky na úrovni souborového systému. Takové tabulky mohou být rozděleny podle partitions (doslova přepážky), jež mohou být definovány přes sloupec, klíč jeho hash atd. Podle typu si lze definovat, na kolik dílů se má tabulka rozdělit, a tolik potom bude daných souborů (pro data i pro klíče). |
|||
⚫ | |||
== Přehled podporovaných vlastností == |
== Přehled podporovaných vlastností == |
||
;verze 3.23 |
;verze 3.23 |
||
* [[cizí klíč]]e (podporovány v |
* [[cizí klíč]]e (podporovány v tabulkách typu [[InnoDB]]) |
||
* [[Databázová transakce|transakce]] (podporovány v |
* [[Databázová transakce|transakce]] (podporovány v tabulkách typu [[InnoDB]]) |
||
* Příkazová replikace |
* Příkazová replikace |
||
* [[fulltext]]ové vyhledávání (od verze 3.23.23)<ref>http://www.fi.muni.cz/~kripac/PV136/zurek/prezentace.html</ref> |
* [[fulltext]]ové vyhledávání (od verze 3.23.23)<ref>http://www.fi.muni.cz/~kripac/PV136/zurek/prezentace.html</ref> |
||
Řádek 76: | Řádek 84: | ||
;verze 4.1 |
;verze 4.1 |
||
* podpora různých znakových sad a porovnávání na úrovni databáze, tabulky i sloupce |
* podpora různých znakových sad a porovnávání na úrovni databáze, tabulky i sloupce |
||
* podpora časových pásem v |
* podpora časových pásem v datech |
||
* [[poddotaz]]y |
* [[poddotaz]]y |
||
* [[R-strom]]y (v |
* [[R-strom]]y (v tabulkách typu [[MyISAM]]) |
||
* podpora „audio“ funkce < |
* podpora „audio“ funkce <tt>SOUNDS_LIKE</tt> |
||
;verze 5.0 |
;verze 5.0 |
||
* [[uložená procedura|uložené procedury]] |
* [[uložená procedura|uložené procedury]] |
||
Řádek 85: | Řádek 93: | ||
* [[Pohled (databáze)|pohledy]] |
* [[Pohled (databáze)|pohledy]] |
||
* práce s [[metadata|metadaty]] |
* práce s [[metadata|metadaty]] |
||
* distribuované XA transakce (v |
* distribuované XA transakce (v tabulkách typu InnoDB) |
||
* kurzory |
* kurzory |
||
* INFORMATION.SCHEMA |
* INFORMATION.SCHEMA |
||
Řádek 108: | Řádek 116: | ||
== Kódování a znakové sady == |
== Kódování a znakové sady == |
||
Od verze 4.1 MySQL řeší ukládání řetězců s |
Od verze 4.1 MySQL řeší ukládání řetězců s podporou [[Unicode]] pomocí nastavení znakové sady (<tt>CHARACTER SET</tt>) <tt>[[Databázový sloupec#COLLATION|COLLATION]]</tt>. To představuje souhrn způsobů, jak k takto uloženému textu přistupovat – porovnávání (s ohledem na případné národnostní zvyklosti), řazení, citlivost velkých malých písmen, ligatur, transkripcí speciálních znaků apod. Znaková sada a collation mohou být nastaveny individuálně pro daný (textový) sloupec, mimo je možnost nastavit výchozí sadu a collation pro tabulku (tu zdědí vytvářené sloupce, u kterých nebyla explicitně vybrána), i celá databáze (tu zase kaskádově zdědí v ní vytvářené tabulky, pokud pro ně není výslovně nastavena). I jednotlivé collations jsou modulární (existují v podobě textových souborů). Jejich aktuální výčet lze zjistit příkazem <tt>[[SHOW]] COLLATION</tt>. |
||
== Rozhraní pro správu databáze == |
|||
⚫ | |||
* [[LAMP]] |
|||
;nástroje pro správu objektů v MySQL |
|||
* [[phpMyAdmin]] |
* [[phpMyAdmin]] |
||
* [[Adminer]] |
* [[Adminer]] |
||
* [[DBeaver]] |
|||
== |
== Odkazy == |
||
⚫ | |||
=== Reference === |
|||
⚫ | |||
<references /> |
|||
* {{Wikiverzita|kurs=MySQL}} |
|||
⚫ | |||
⚫ | |||
=== Externí odkazy === |
|||
* {{en}} [http://www.mysql.com/ www.mysql.com] – Oficiální stránky |
|||
⚫ | |||
* [http://cs.wikiversity.org/wiki/MySQL MySQL na Wikiverzitě beta] |
|||
⚫ | |||
* Seriály na ABC Linuxu: |
* Seriály na ABC Linuxu: |
||
** [http://www.abclinuxu.cz/clanky/navody/tvorba-databazi-v-mysql-i Tvorba databází v |
** [http://www.abclinuxu.cz/clanky/navody/tvorba-databazi-v-mysql-i Tvorba databází v MySQL, 6 dilů] |
||
** [http://www.abclinuxu.cz/clanky/navody/sprava-databazi-v-mysql-i Správa databází v |
** [http://www.abclinuxu.cz/clanky/navody/sprava-databazi-v-mysql-i Správa databází v MySQL, 3 díly] |
||
* [http://www. |
* [http://www.junext.net/mysql českojazyčný MySQL manuál] |
||
* [http://www.junext.net/mysql Český MySQL manuál] |
|||
* {{en}} [http://www.mysqlperformanceblog.com/2006/09/29/what-to-tune-in-mysql-server-after-installation/ MySQL tuning] - jak vyladit nastavení MySQL serveru |
|||
{{Pahýl}} |
{{Pahýl}} |
||
{{Autoritní data}} |
|||
{{Portály|Internet}} |
|||
[[Kategorie:MySQL| ]] |
|||
[[Kategorie:Systémy řízení báze dat]] |
[[Kategorie:Systémy řízení báze dat]] |
||
[[Kategorie:Software firmy Sun Microsystems]] |
[[Kategorie:Software firmy Sun Microsystems]] |
||
[[Kategorie: |
[[Kategorie:Software pod licencí GPL]] |
Aktuální verze z 30. 1. 2024, 16:33
Snímek příkazové řádky MySQL | |
Vývojář | Oracle Corporation |
---|---|
První vydání | 23. května 1995 |
Aktuální verze | 8.3.0[1] (16. ledna 2024) |
Operační systém | Windows, GNU/Linux, Solaris, macOS, FreeBSD |
Vyvíjeno v | C, C++ |
Typ softwaru | Relační databáze |
Licence | GPL (verze 2) nebo komerční[2] |
Lokalizace | anglicky |
Web | www.mysql.com |
Některá data mohou pocházet z datové položky. |
MySQL je otevřený systém řízení báze dat uplatňující relační databázový model, vytvořený švédskou firmou MySQL AB, nyní vlastněný společností Oracle Corporation. Jeho hlavními autory jsou Michael „Monty“ Widenius a David Axmark. Je považován za úspěšného průkopníka dvojího licencování – je k dispozici jako svobodný a otevřený sofware pod bezplatnou licencí GPL, tak pod řadou komerčních placených licencí.
MySQL je multiplatformní databáze. Komunikace s ní probíhá – jak už název napovídá – pomocí jazyka SQL. Podobně jako u ostatních SQL databází se jedná o dialekt tohoto jazyka s některými rozšířeními.
Pro svou snadnou implementovatelnost (lze jej instalovat na GNU/Linux, MS Windows, ale i další operační systémy), výkon a především díky tomu, že se jedná o volně šiřitelný software, má vysoký podíl na v současné době používaných databázích. Velmi oblíbená a často nasazovaná je kombinace GNU/Linux, Apache, MySQL a programovacího jazyka PHP, jako základní software webového serveru („technologie LAMP“).
MySQL bylo od počátku optimalizováno především na rychlost, a to i za cenu některých zjednodušení: má jen jednoduché způsoby zálohování; od roku 2005 podporuje i tzv. pohledy, triggery, a uložené procedury.[3]
Architektura MySQL serveru
[editovat | editovat zdroj]Architektura MySQL se velmi odlišuje od architektur jiných databázových serverů, má široký záběr a je užitečná pro řešení mnoha různorodých úloh. Nejsvrchnější vrstva obsahuje služby, jež nejsou jedinečné pro MySQL. Obsluhují většinu potřebných nástrojů klient/server, které jsou založeny na síti.
Ve druhé vrstvě se nachází valná část mozku MySQL, včetně kódu pro rozbor (parsing), analýzu, optimalizaci a pro všechny zabudované funkce. Na této úrovni se nachází veškerá funkcionalita, která se poskytuje prostřednictvím úložných enginů.
Třetí vrstva obsahuje úložné enginy. Ty mají na starosti ukládání a získávání všech dat uložených v MySQL. Server komunikuje s úložnými enginy prostřednictvím API úložných enginů. Toto rozhraní skrývá rozdíly mezi jednotlivými úložnými enginy a činí je na vrstvě dotazů velmi transparentními. API obsahuje několik desítek nízkoúrovňových funkcí, které provádějí operace jako „zahájit transakci“ nebo „získat řádek, který má tento primární klíč“. Úložné enginy nedělají rozbor SQL a nekomunikují mezi sebou – jednoduše pouze odpovídají na požadavky serveru.
Správa připojení a bezpečnost
[editovat | editovat zdroj]Každé klientské připojení dostane uvnitř serverového procesu vlastní vlákno (thread). Dotazy tohoto připojení se vykonávají uvnitř tohoto jediného vlákna, které zase sídlí na jednom jádru nebo CPU. Protože server udržuje vlákna v cache, nemusejí se vytvářet a likvidovat pro každé nové připojení. Autentizace je založena na uživatelském jménu, hostiteli, odkud pocházejí a heslu. Dají se také používat certifikáty X509 přes připojení SSL. Jakmile se klient připojí, server pro každý dotaz vydaný klientem ověřuje, zdali má patřičná oprávnění pro akci, kterou chce vykonat.
Optimalizace a vykonávání
[editovat | editovat zdroj]MySQL provádí rozbor dotazů proto, aby vytvořil interní stromovou strukturu (parse tree), pak aplikuje všelijaké optimalizace. Může dotaz přepsat, určit pořadí, v němž bude číst tabulky, zvolit, které indexy použije atd. Prostřednictvím speciálních klíčových slov může programátor optimalizátoru předat tzv. pokyny, jimiž se dá ovlivnit rozhodovací proces. Optimalizátor se ve skutečnosti nestará o to, který úložný engine používá konkrétní tabulka. Úložný engine ovšem ovlivňuje, jak server optimalizuje dotaz. Optimalizátor od úložného enginu zjišťuje, zdali má jistou výbavu, ptá se na náklady jistých operací a dotazuje se na statistiky o datech tabulky.
Ovšem ještě dřív než server začne s rozborem dotazu, obrátí se na cache dotazů (query cache), kam může ukládat pouze příkazy pro výběr, SELECT společně s jejich výslednými sadami. Jestliže někdo vydá dotaz, který je identický s nějakým dotazem, který je už k dispozici v cache, server nemusí dělat vůbec žádný rozbor, nemusí nic optimalizovat a dokonce nemusí dotaz ani vykonat – jednoduše pouze předá zpět uloženou výslednou sadu.
Úložné databázové stroje (úložiště dat)
[editovat | editovat zdroj]MySQL nabízí několik typů databázových úložišť (storage engine), které se liší svými možnostmi, použitím a způsobem ukládání dat do souborů:
- ARCHIVE – stroj uzpůsobený pro ukládání velkého množství neindexovaných dat.
- BLACKHOLE – stroj, který data přijímá, ale neukládá je (zahazuje je).
- CSV – ukládá data v textovém formátu CSV.
- EXAMPLE – nefunkční stroj, který slouží jako ilustrační pro potřeby zdrojových kódů databáze MySQL a využijí ho tedy jen její vývojáři.
- FEDERATED – umožňuje uživateli vytvořit tabulku, která je lokální reprezentací cizí (vzdálené) tabulky.
- InnoDB – stroj navržen pro zpracování transakcí.
- MEMORY nebo HEAP – vysoce výkonné úložiště, který data uchovává pouze v operační paměti, při restartu serveru jsou data ztracena.
- MERGE – sloučení dat z několika MyISAM tabulek o stejné struktuře, starší alternativa k partition.
- MyISAM – výchozí formát úložiště dat v databázovém systému MySQL, který podporuje fulltextové vyhledávání.
Před koupí MySQL Oraclem byl vyvíjen ještě stroj Falcon, ale Oracle jeho vývoj ukončil.
Úložiště fungují jako moduly, které lze k distribuci tohoto databázového systému doinstalovat; jejich aktuální seznam lze zjistit příkazem SHOW ENGINES nebo SELECT * FROM information_schema.ENGINES. Každé úložiště ukládá data tabulky a její případné klíče jinak, definici tabulky ovšem zpracovává samotný server.
Ukládání dat
[editovat | editovat zdroj]MySQL ukládá každou databázi (také se jim říká schéma) do podadresáře svého datového adresáře na odkladovém souborovém systému (dá se změnit klauzulí DATA DIRECTORY a INDEX DIRECTORY). Každá vytvořená tabulka (s výjimkou enginů BLACKHOLE, MEMORY, EXAMPLE) je MySQL uložena do souborů s těmito příponami:
- .frm – definice tabulky
- .MYD – data tabulky
- .MYI – klíče tabulky
Závislost na diskovém systému
[editovat | editovat zdroj]Na rozdíl od databázových řešení, držící databázi v jednom souboru (MS Access, SQLite) v MySQL název adresáře odpovídá názvu databáze a název souboru (bez přípony) odpovídá názvu tabulky. Jelikož MySQL používá při ukládání definic souborový systém, otázka rozlišování velikosti písmen je závislá na platformě. Na instalaci MySQL na Windows se velikost písmen v názvech tabulek a databází nerozlišuje, na unixových systémech se velikost písmen rozlišuje. Databáze i tabulky mohou být pojmenovány téměř libovolně, mohou sestávat jen z číslic, obsahovat mezery, speciální znaky i znaky Unicode (kromě znaků s kódem 0 a nad 65 535). V MySQL se pak takové jméno uvádí ve zpětných jednoduchých uvozovkách (`) – to platí i v případě, je-li název tabulky/databáze shodný s nějakým z klíčových slov SQL. Identifikátor může dokonce obsahovat i zpětnou uvozovku, v tom případě je tento znak zdvojen. V souborovém systému je pak každý takový znak (tj. každý kromě A–Z, a–z, 0–9 a _) zakódován do sekvence @ + ASCII kódu daného znaku (dle UTF-16, uvedeného hexadecimálně jako 4 číslice, doplněném nulami, např. mezera jako @0020). MySQL pak interně dělá příslušné konverze při každém přístupu k těmto adresářům a souborům. To, které znaky takto budou zakódovány, je závislé na souborovém resp. operačním systému, stejně jako případné limity v maximální délce názvu souboru či adresáře (podle dokumentace 64, ale v případě, že každý bude zakódován, to dělá 320 znaků oproti 255 znakům např. v NTFS), maximálním počtu tabulek v databázi nebo databází v systému a výše zmíněné (ne)rozlišování velikosti písmen. Z tohoto důvodu se nedoporučuje vkládat do názvů databází a tabulek „nekonvenční“ znaky, používat znaky s diakritikou a na unixových systémech (včetně Linuxu) se silně nedoporučuje používat databáze/tabulky nazvané stejně, rozlišené jen velikostí písmen.
Další prvek, který koresponduje s vytvářením souborů na disku, je tzv. partitioning, to jest vnitřní rozdělení tabulky na úrovni souborového systému. Takové tabulky mohou být rozděleny podle partitions (doslova přepážky), jež mohou být definovány přes sloupec, klíč jeho hash atd. Podle typu si lze definovat, na kolik dílů se má tabulka rozdělit, a tolik potom bude daných souborů (pro data i pro klíče).
Přehled podporovaných vlastností
[editovat | editovat zdroj]- verze 3.23
- cizí klíče (podporovány v tabulkách typu InnoDB)
- transakce (podporovány v tabulkách typu InnoDB)
- Příkazová replikace
- fulltextové vyhledávání (od verze 3.23.23)[4]
- verze 4.0
- sjednocování dotazů pomocí UNION
- verze 4.1
- podpora různých znakových sad a porovnávání na úrovni databáze, tabulky i sloupce
- podpora časových pásem v datech
- poddotazy
- R-stromy (v tabulkách typu MyISAM)
- podpora „audio“ funkce SOUNDS_LIKE
- verze 5.0
- uložené procedury
- triggery
- pohledy
- práce s metadaty
- distribuované XA transakce (v tabulkách typu InnoDB)
- kurzory
- INFORMATION.SCHEMA
- verze 5.1
- partitioning
- časování událostí (Event Scheduler)
- úložiště IBMDB2I (tabulky typu IBM DB2, podporující transakce)
- rozšiřitelné API
- replikace na úrovni řádků
- logování na straně serveru
- plánováno ve verzi 6
- cizí klíče (i pro jiné tabulky než InnoDB)
- použití cizích i fulltextových klíčů současně
Kódování a znakové sady
[editovat | editovat zdroj]Od verze 4.1 MySQL řeší ukládání řetězců s podporou Unicode pomocí nastavení znakové sady (CHARACTER SET) COLLATION. To představuje souhrn způsobů, jak k takto uloženému textu přistupovat – porovnávání (s ohledem na případné národnostní zvyklosti), řazení, citlivost velkých malých písmen, ligatur, transkripcí speciálních znaků apod. Znaková sada a collation mohou být nastaveny individuálně pro daný (textový) sloupec, mimo je možnost nastavit výchozí sadu a collation pro tabulku (tu zdědí vytvářené sloupce, u kterých nebyla explicitně vybrána), i celá databáze (tu zase kaskádově zdědí v ní vytvářené tabulky, pokud pro ně není výslovně nastavena). I jednotlivé collations jsou modulární (existují v podobě textových souborů). Jejich aktuální výčet lze zjistit příkazem SHOW COLLATION.
Rozhraní pro správu databáze
[editovat | editovat zdroj]Odkazy
[editovat | editovat zdroj]Reference
[editovat | editovat zdroj]- ↑ Changes in MySQL 8.3.0 [online]. mysql.com, 2024-01-16 [cit. 2024-01-30]. Dostupné online. (anglicky)
- ↑ Downloads [online]. MySQL [cit. 2014-08-03]. Dostupné online.
- ↑ ABIS Infor - MySQL: stored procedures and SQL/PSM. www.abis.be [online]. [cit. 2020-04-11]. Dostupné online.
- ↑ http://www.fi.muni.cz/~kripac/PV136/zurek/prezentace.html
Související články
[editovat | editovat zdroj]Externí odkazy
[editovat | editovat zdroj]- Obrázky, zvuky či videa k tématu MySQL na Wikimedia Commons
- Výukový kurs MySQL ve Wikiverzitě
- Seriály na ABC Linuxu:
- českojazyčný MySQL manuál