Když se nad tím zamyslíme trochu podrobněji, zjistíme, že bychom asi
v seznamu písní nechtěli mít všechny písně, ale jen ty, které ještě v
databázi nemají zadaný text. Jak to jednoduše udělat? Poradím Vám trik,
kterým to zjistíte pomocí dotazu do databáze. Může se Vám to hodit.
Původní, "hloupý" databázový dotaz sestavující seznam písní mohl
docela dobře být:
select id, nazev from
pisne order by nazev
Má však, jak již jsme uvedli tu nectnost, že vrátí i ty písně, které
už text mají. Vylepšený dotaz bude tento:
select pisne.id,
pisne.nazev from pisne left join texty on pisne.id = texty.pisen where
texty.pisen is null order by nazev
Pokud se zrovna denně nepohybujete v databázích, dovolím si to
trochu vysvětlit. Dotaz spojuje (join) data ze dvou tabulek (pisne a
texty), a to pomocí tzv. levého vnějšího spojení (LEFT OUTER JOIN). To
znamená, že dotaz vrátí všechny záznamy z "levé" tabulky (v našem
případě tabulky pisne), a to i v případě, že odpovídající záznam v
"pravé" tabulce (v našem případě je to tabulka texty) neexistuje. Pokud
se to stane, jsou v odpovídajících polích vráceny hodnoty NULL. Nás
však shodou okolností zajímají POUZE písně bez textů, takže tomu musíme
trochu pomoci a vybrat tyto řádky pomocí klauzule where. Česky bychom
dotaz mohli převyprávět jako:"Vyber všechny záznamy z tabulky písní,
kde odpovídající text písně nelze najít."
Kromě toho dotazu je funkce pro nahrání písní do rozevíracího
seznamu prakticky totožná s funkcí, pomocí níž jsme nahrávali seznam
písní do diskografie.
Nemusíme se jí tedy příliš dopodrobna zabývat.
Uložení do databáze
Tuto věc jsme řešili v díle o ukládání
binárních dat do databáze. Aby uložení dat dopadlo dobře, musejí se
udělat zhruba tyto kroky:
- Nejprve uklidíme (možná existující) dočasné soubory
- Ověříme si pomocí funkce move_uploaded_file,
zda se soubor podařilo nahrát a přesunout na námi zvolené místo.
- Pokud ano, zjistíme si jeho délku. Soubory s nulovou délkou a
příliš dlouhé soubory ze zpracování vyloučíme.
- Nahrajeme obsah souboru do proměnné
- Ošetříme tuto proměnnou pomocí addslashes,
abychom ji mohli použít pro bezpečné uložení do databáze.
- Provedeme vlastní databázový dotaz.
- Jelikož to mohlo z různých důvodů selhat, budeme testovat, zda se
povedlo řádek vložit. Pokud ne, zobrazíme chybu.
- Každopádně odstraníme dočasný soubor.
Celý skript je nesmírně přímočarý a jednoduchý na pochopení. Příště
si ukážeme, jak texty písní registrovaným uživatelům zpřístupnit a jak
jim je umožnit postahovat.
Změny na portálu
Na současný stav projektu se můžete na našem webu podívat
nebo si jej můžete stáhnout.
Pozn.: Aby Vám stažená verze
fungovala na lokálním stroji, upravte si hodnotu konstant SQL_HOST,
SQL_USERNAME, SQL_PASSWORD a SQL_DBNAME. Případně si je můžete včlenit
do konfiguračního souboru podobně, jako jsem to udělal v souboru
func.php.