Jihokorejská Národní daňová služba (NTS) zabavila kryptoměnu Pre-retogeum (PRTG) v hodnotě 5,6 milionu dolarů. Pochlubila se v tiskové zprávě, do které vložila fotografii zabavených USB flash disků s kryptoměnovými peněženkami spolu se souvisejícími ručně napsanými mnemotechnickými obnovovacími frázemi. Krátce na to byla kryptoměna v hodnotě 4,8 milionu dolarů odcizena. O několik hodin ale vrácena, jelikož PRTG je extrémně nelikvidní, s denním objemem obchodování kolem 332 dolarů a zalistováním na jediné burze, MEXC [Bitcoin.com].
Komunita kolem Linuxu From Scratch (LFS) vydala nové verze knih s návody na instalaci vlastního linuxového systému ze zdrojových kódů Linux From Scratch 13.0 a Beyond Linux From Scratch 13.0. Pouze se systemd.
Byla vydána nová stabilní major verze 25.12 linuxové distribuce primárně určené pro routery a vestavěné systémy OpenWrt (Wikipedie). Jedná se o nástupce předchozí major verze 24.10. Přehled novinek v poznámkách k vydání. Podporováno je více než 2200 zařízení.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za únor (YouTube). Odstraněn byl veškerý kód napsaný ve Swiftu. JavaScriptový engine LibJS byl reimplementován v Rustu.
Byla vydána verze 1.94.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example. Zveřejněny byly výsledky průzkumu mezi vývojáři v programovacím jazyce Rust: 2025 State of Rust Survey Results.
Google zveřejnil seznam 185 organizací přijatých do letošního Google Summer of Code (GSoC). Dle plánu se zájemci přihlašují od 16. do 31. března. Vydělat si mohou od 750 do 6600 dolarů. V Česku a na Slovensku je to 900 dolarů za malý, 1800 dolarů za střední a 3600 dolarů za velký projekt. Další informace v často kladených otázkách (FAQ). K dispozici jsou také statistiky z minulých let.
Byla vydána únorová aktualizace aneb nová verze 1.110 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.110 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Apple představil 13palcový MacBook Neo s čipem A18 Pro. V základní konfiguraci za 16 990 Kč.
Kalifornský zákon AB 1043 platný od 1. ledna 2027 vyžaduje, aby operační systémy požadovaly po uživatelích věk nebo datum narození a skrze API poskytovaly aplikacím informaci, zda je uživatel mladší 13 let, má 13 až 16 let, má 16 až 18 let nebo má alespoň 18 let. Vývojáři linuxových distribucí řeší, co s tím (Ubuntu, Fedora, …).
Konference LinuxDays 2026 proběhne o víkendu 3. a 4. října v Praze v areálu ČVUT v Dejvicích na FIT. Čekají vás desítky přednášek, workshopy, stánky a setkání se spoustou chytrých lidí.
Pokud jste se už naučili jazyk SQL, můžete se svými znalostmi vytvořit dobře strukturovanou databázi, pomocí příkazů SQL ji můžete dokonce zaplnit daty a dotazy z ní získávat data. Nenechte se tím zmást a vězte, že jste stále ještě na začátku cesty poznání databázového systému MySQL.
Dnes se seznámíte s trochu pokročilejšími aspekty tvorby databází - klíči a zamykáním záznamů.
Při předchozím studiu jste se setkali s primárními klíči. Dnes se budu zabývat klíči komplexněji.
Klíče (nebo také indexy) urychlují vyhledávání v databázi. Pokud přidáme do tabulky klíč, vlastně ji setřídíme.
WHERE.
Pokud se tedy pole často vyskytuje v příkazu WHERE, je vhodné
přiřadit mu klíč.ORDER
BY a GROUP BY.MIN() a
MAX()(
Poznámka ke konvenci zápisu syntaxe příkazů:
ALTER TABLE tabulka ADD {KEY | INDEX} index ({sloupec1, sloupec2,...});
ALTER TABLE tabulka ADD UNIQUE index ({sloupec1, sloupec2,...});
ALTER TABLE tabulka ADD PRIMARY KEY index ({sloupec1, sloupec2,...});
[slovo] - slovo uzavřené v těchto závorkách je
nepovinné
{slovo1, slovo2, slovo3} - minimálně jedno z uvedených slov
musí být uvedeno
[slovo1| slovo2] - jedno z těchto slov bude může být nepovinně
uvedeno
)
Pokud budete chtít klíč odstranit, nahradíte slovo ADD slovem
DROP
Toto je upřednostňovaný postup při vytváření klíčů. Můžete ale také použít tyto příkazy:
CREATE INDEX index ON tabulka ({sloupec1, sloupec2,...}]);
CREATE UNIQUE INDEX [index] ON tabulka ({sloupec1, sloupec2,...});
CREATE PRIMARY KEY ON tabulka ({sloupec1, sloupec2});
Klíče můžete také definovat při vytváření tabulky:
CREATE TABLE tabulka (sloupec datovýtyp [NULL | NOT NULL],
KEY col_index(sloupec));
Informace o klíčích v dané tabulce zobrazíte pomocí příkazu:
SHOW {KEYS | INDEX} FROM tabulka
Jednopoložkové klíče jsou nejjednodušší klíče. Jednopoložkový klíč k
sloupci Jmeno_Prokuktu vytvoříte například takto:
ALTER TABLE Produkty ADD KEY produkt_idx (Jmeno_Produktu);
Pokud k definici klíče použijete více než jedno pole, vytvoříte vícepoložkový klíč. Vícepoložkový klíč vytvoříte například takto:
ALTER TABLE Produkty ADD KEY sloz_idx (Jmeno_Produktu, Zeme_Puvodu, Barva);
Rozdíl mezi jednoduchým a složeným klíčem můžete vidět v následující tabulce:
| Jmeno_Produktu | Zeme_Puvodu | Barva | produkt_idx | sloz_idx |
| Monitor | China | Šedá | Monitor | MonitorChinaŠedá |
| Myš | Japan | Šedá | Myš | MyšJapanŠedá |
| Klávesnice | Japan | Černá | Klávesnice | KlávesniceJapanČerná |
Zkuste po vytvoření složeného indexu zadat příkaz:
SHOW KEYS FROM tabulka;
Jmeno_Produktu je více omezující než sloupec
Zeme_puvodu).Částečné klíče se používají pro indexování určitého počtu prvních znaků sloupce textového datového typu.
Částečné klíče je vhodné použít, pokud by mohl být indexovaný sloupec příliš dlouhý. Částečný klíč vytvoříte například takto:
ALTER TABLE Produkty ADD KEY produkt_idx (Jmeno_Produktu(5));
Složený klíč můžete samozřejmě skládat i z částečných klíčů.
Používání částečných klíčů je výhodné, protože bývají kratší a jejich výkon je tedy zpravidla vyšší.
Jedinečné klíče nedovolují v indexovaných polích existenci duplicitních položek. Tabulka může obsahovat více než jeden jedinečný klíč. Jedinečný klíč vytvoříte příkazem:
ALTER TABLE tabulka ADD UNIQUE index (pole[...]);
Primární klíč je speciální typ jedinečného klíče. Na rozdíl od běžného
jedinečného klíče smí být v tabulce pouze jeden primární klíč a pole
definované jako primární klíč nesmí obsahovat prázdné hodnoty
(NULL).
Primární klíč se používá pro vytvoření relace mezi tabulkami.
Pokud nelze jedinečnost primárního klíče zajistit pomocí jednoho pole,
používá se vícepoložkový primární klíč. Vícepoložkový primární klíč nelze
vytvořit pomocí příkazu CREATE TABLE, ale jedině pomocí
příkazu ALTER TABLE. Složený primární klíč vytvoříte
například takto:
ALTER TABLE Produkty ADD PRIMARY KEY (Jmeno_Produktu, Zeme_Puvodu);
Pokud vytvoříte takový primární klíč, nebudete moci mít v dané tabulce více produktů stejného názvu a stejné země původu!
Můžete samozřejmě vytvořit i složený částečný primární klíč.
Vytvoření primárního klíče z reálných dat bývá často nevhodné. Často se jen těžko hledá taková kombinace sloupců, která je pokaždé jiná.
V takových případech je nejlepší vytvořit syntetický klíč. To je sloupec speciálně vytvořený pro to, aby se stal primárním. Je to tedy sloupec, který obsahuje data, která bychom jinak nepotřebovali. V našem příkladě bychom vytvořili pro každý produkt jedinečné identifikační číslo.
Naši tabulku vytvoříte příkazem:
CREATE TABLE Produkty (ID_Produktu INT(8) AUTO_INCREMENT
PRIMARY KEY NOT NULL, Jmeno_Produktu VARCHAR(20), ...)
Fulltextové klíče jsou v MySQL poměrně nové - jejich podpora byla do MySQL přidána ve verzi 3.23.23.
Fulltextový klíč se smí vytvářet pouze ze sloupců typu
VARCHAR a TEXT. Fulltextový klíč vytvoříte
například takto:
ALTER TABLE Knihy ADD FULLTEXT INDEX (Nazev_Knihy, Ukazka);
V takto indexovaných sloupcích můžete použít velmi rychlé fulltextové
vyhledávání. Vyhledávání se realizuje pomocí klíčových slov
MATCH(pole_ve_kterem_chcete_hledat1, pole_ve_kterem_chcete_hledat2,
...) a AGAINST(hledaný výraz).
Pokud použijete klíčová slova MATCH a AGAINST
v klauzuli WHERE, výsledný výpis bude sestupně setřízený
podle četnosti hledaných slov v prohledávaných sloupcích.
Pokud hledaný výraz obsahuje víc slov, bere MySQL při výpočtu četnosti hledaných slov v prohledávaných sloupcích ohled i na to, jaké ze slov je obsaženo ve více záznamech. To, které je obsaženo ve více záznamech, má menší váhu (pokud je obsaženo v 50 a více procentech záznamů, tak nemá dokonce žádnou váhu - viz dále ), protože má menší sémantickou hodnotu. (slovo, které je v méně záznamech pravděpodobně určuje blíže, to co chcete najít)
Pozor:
MATCH() musí být
ze stejné tabulky a musí být částí stejného fulltextového klíče.AGAINST musí být řetězec.
.Od verze 4.0 podporuje MySQL v hledaných výrazech dokonce i booleanovské operátory. Můžete použít tyto operátory:
+ (+slovo znamená, že slovo musí
být obsaženo v každém záznamu)- (-slovo znamená, že slovo
nemusí být obsaženo v každém záznamu)< a > mohou být užity ke
zvýšení/snížení váhy slova~ může být použit k udělení negativní váhy slovu* zástupný operátorPříklady:
SELECT * FROM Knihy WHERE MATCH (Nazev_Knihy, Ukazka) AGAINST ('databáze');
Tento dotaz vrátí všechny záznamy obsahující ve sloupci
Nazev_Knihy nebo ve sloupci Ukazka slovo
databáze. Výpis bude sestupně setřízený podle procentuální
četnosti hledaných slov.
SELECT ID_Knihy, MATCH (Nazev_Knihy, Ukazka) AGAINST ('databáze') as Score
FROM Knihy;
Tento dotaz zobrazí sloupec ID_Knihy a sloupec
Score, ve kterém bude číslo (0 znamená, že v daných
prohledávaných sloupcích se slovo databáze nevyskytuje,
desetinné číslo určuje četnost slova databáze v prohledávaném
sloupci vztaženou na počet slov tohoto sloupce => čím větší číslo, tím
větší procentuální četnost) všech záznamů z tabulky Knihy.
Výpis nebude setřízený
SELECT ID_Knihy, MATCH (Nazev_Knihy, Ukazka) AGAINST ('databáze') as score
FROM Knihy
WHERE MATCH (Nazev_Knihy, Ukazka) AGAINST ('databáze');
Jako předchozí dotaz, ale záznamy setřídí a vypíše jen záznamy, ve kterých se tato hledaná slova vyskytovala.
K databázi může přistupovat více lidí současně. Pokud je nějaký dotaz na databázi závislý na aktuálním stavu dat, který by jiný dotaz mohl změnit, je nutné uzamknout příslušný záznam.
Taková situace by mohla nastat, pokud bychom v databázi evidovali množství zásob na skladu a podle toho určovali dodací lhůty. Jeden proces by zjistil množství zásob na skladu, vypočítal by dodací lhůtu a pak by odečetl objednané zboží od zboží na skladu. Pokud by ale do databáze přistoupil druhý proces těsně po prvním (ještě před tím, než první odečte objednané zboží od zboží na skladu), získal by špatná data.
LOCK TABLES tabulka1 [AS alias] {READ | [LOW_PRIORITY] WRITE}
[, tabulka2 {READ | [LOW_PRIORITY] WRITE} ...]
Tabulku odemknete příkazem:
UNLOCK TABLES
Tabulky lze zamykat pro čtení (READ) - znamená to, že
ostatní procesy budou moci z tabulky pouze číst (a nebudou do ní moci
zapisovat).
Dále lze tabulky zamykat pro zápis (WRITE) - pak bude moci
tabulku používat pouze proces, který ji uzamkl - získá k ní výhradní
přístup.
Pokud dostane databáze více příkazů LOCK TABLES, řadí se tyto příkazy do fronty. Požadavky na výhradní přístup mají přednost před požadavky na otevření tabulek jen pro čtení.
Pokud zadáte příkaz LOW_PRIORITY WRITE, bude MySQL dávat
přednost požadavkům na čtení před požadavky na výhradní přístup. Tento
příkaz zadejte, pokud je ve vaší databázi důležitější otevření tabulky pro
čtení než otevření tabulky ve výhradním režimu.
Zadáte-li příkaz SELECT HIGH_PRIORITY, můžete z tabulek
číst, i když je na tuto tabulku vystaven požadavek na výhradní
přístup.
LOCK TABLESINSERT) může dojít ke zvýšení výkonu.LOCK TABLES se používá při zálohování databáze.
Pokud by někdo zapisoval do databáze v průběhu zálohování, mohla by se
porušit konzistence dat.Dnes jste nabyli další velmi významné dovednosti potřebné ke zvládnutí
MySQL. Klíče jsou nezbytné při tvorbě relací, mohou významně zvýšit
vykonání klauzule WHERE. V neposlední řadě můžete použít
fulltextové klíče k fulltextovému hledání.
Zamykání záznamů se používá k odstranění problémů vzniklých v důsledku mnohonásobného přístupu.
V příštím dílu se seznámíte s nejdůležitějšími funkcemi v MySQL.
Nástroje: Tisk bez diskuse
Tiskni
Sdílej: