MySQL – 4. lekcia
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama
Reklama

MySQL – 4. lekciaMySQL – 4. lekcia

 

MySQL – 4. lekcia

Google       Google       20. 1. 2006       30 314×

V dnešnej lekcii:
* príkaz WHERE
* logické operátori
* doplňovanie a mazanie dát
* príkaz COUNT
..

Reklama
Reklama

Príkaz WHERE

Takže s príkazom SELECT sme sa oboznámili v predchádzajúcom diele. Vieme už vypísať všetky dáta z tabuliek, ale aj iba niektoré stĺpce.
Niekedy sa ale stáva, že budeme potrebovať vypísať iba dáta, ktoré napr. majú ID=2, alebo v určitom stĺpci obsahujú nejaké slovo, podľa ktorého ho nájdeme.
Na to nám slúži príkaz WHERE. Syntaxa je:

SELECT stĺpec FROM meno_tabulky WHERE stĺpec=“neaka_hodnota“;

Takže nasledujúci výraz nám z našej tabuľky programovanie vyberie zo stĺpca iba názov “Jazyk SQL“

mysql> SELECT mysql FROM programovanie WHERE mysql="Jazyk SQL";

Odpoveď servera:

+-----------+
| mysql     |
+-----------+
| Jazyk SQL |
+-----------+
1 row in set (0.02 sec)


Takže na tomto príklade krásne vidíme, ako nám MySQL server vráti iba stĺpec s jedným názvom “Jazyk SQL“.
Teraz si skúsme vyskúšať vybrať všetky záznamy, ktoré obsahujú poradové ID 2.

mysql> SELECT*FROM programovanie WHERE ID="2";

Odpoveď servera:

+---------------------+----------+----------------+------------+----+
| php                 | mysql    | html           | datum      | ID |
+---------------------+----------+----------------+------------+----+
| Programovanie v PHP | Databázy | Tvorba stránok | 2005-12-11 |  2 |
+---------------------+----------+----------------+------------+----+
1 row in set (0.11 sec)

Logické operátori

Povedzme, že budeme chcieť získať všetky záznamy, v ktorých mysql="Databázy" a kde html=“Tvorba stránok“.


mysql> SELECT*FROM programovanie WHERE mysql="Databázy" AND html="Tvorba stránok";

Odpoveď servera:

+---------------------+----------+----------------+------------+----+
| php                 | mysql    | html           | datum      | ID |
+---------------------+----------+----------------+------------+----+
| Programovanie v PHP | Databázy | Tvorba stránok | 2005-12-11 |  1 |
| Programovanie v PHP | Databázy | Tvorba stránok | 2005-12-11 |  2 |
+---------------------+----------+----------------+------------+----+
2 rows in set (0.00 sec)

Použili sme na to logický operátor AND, ktorý funguje na princípe:
Vyber všetko z tabuľky_programovanie, kde mysql je rovné "Databázy" a html je rovné "Tvorba stránok".
Môžeme využiť aj logického operátora OR.

mysql> SELECT*FROM programovanie WHERE mysql="Jazyk SQL" OR ID="1";

Odpoveď servera:

+---------------------+-----------+----------------+------------+----+
| php                 | mysql     | html           | datum      | ID |
+---------------------+-----------+----------------+------------+----+
| Programovanie v PHP | Databázy  | Tvorba stránok | 2005-12-11 |  1 |
| NULL                | Jazyk SQL | Tag body       | 2005-12-26 |  3 |
+---------------------+-----------+----------------+------------+----+
2 rows in set (0.06 sec)

Príncíp:
Vyber všetko z tabuľky_programovanie, kde mysql je rovné "Databázy" alebo html je rovné "Tvorba stránok".

Doplňovanie a mazanie dát

Určite sa stretneme s tým, že svoje tabuľky budeme neskôr chcieť upravovať alebo mazať. Možno budete chcieť niekedy zmazať záznam úplne. Ak si spomínate, v minulom diele sme si hovorili o nulových hodnotách. V tom prípade sme nezadali nič pri stĺpci php v treťom riadku s poradovým ID=3.Poďme ju teda teraz doplniť.
Pre aktualizáciu záznamu používame výraz UPDATE, jeho syntaxa je:


UPDATE meno_tabulky SET meno_stlpca=“Text“  WHERE meno_stlpca=“hodnota_v_stlpci“;


mysql> UPDATE programovanie SET php="Dynamicke stranky" WHERE ID="3";

Odpoveď servera:

Query OK, 1 row affected (0.12 sec)
Rows matched: 1  Changed: 1  Warnings: 0

Všimnime si, ako nás MySQL server informuje o zmene záznamu. Takže teraz si overíme zmenený záznam.

mysql> SELECT*FROM programovanie WHERE ID="3";

Odpoveď servera:

+-------------------+-----------+----------+------------+----+
| php               | mysql     | html     | datum      | ID |
+-------------------+-----------+----------+------------+----+
| Dynamicke stranky | Jazyk SQL | Tag body | 2005-12-26 |  3 |
+-------------------+-----------+----------+------------+----+
1 row in set (0.00 sec)

Niekedy sa stretneme aj s tým, že budeme nútený náš záznam vymazať. Na to sa používa výraz DELETE. Základná syntaxa vyzerá takto:

DELETE FROM meno_tabulky WHERE meno_stlpca=“Nejaka_hodnota“;

Pri mazaní záznamu je lepšie používať aj identifikátor ID, abysme sa uistili predtým, ako ho zmažeme.
Takže teraz si poďme zmazať záznam obsahujúci názov “Dynamicke stranky“.

mysql> DELETE FROM programovanie WHERE php="Dynamicke stranky" AND ID="3";

Odpoveď servera:

Query OK, 1 row affected (0.04 sec)

Teraz sa presvedčíme, že sme náš záznam úspešne zmazali.

mysql> SELECT*FROM programovanie WHERE ID="3";

Odpoveď servera:

Empty set (0.00 sec)

Príkaz COUNT

Výraz COUNT slúži k práci s riadkami. Vracia počet riadkov. Syntaxa je:


SELECT  COUNT(*) FROM  meno_tabulky;


mysql> SELECT COUNT(*) FROM programovanie;

Odpoveď servera:

+----------+
| COUNT(*) |
+----------+
|        2 |
+----------+
1 row in set (0.09 sec)

Tento výraz nám zobrazil aktuálny počet riadkov v tabuľke programovanie.
Exitujú aj iné syntaxy výrazu COUNT. Skúsme si zobraziť, v koľkých riadkov sa nám napr. nachádza slovo Databázy.

mysql> SELECT COUNT(*) AS mysql FROM programovanie WHERE mysql="Databázy";

Odpoveď servera:

+-------+
| mysql |
+-------+
|     2 |
+-------+
1 row in set (0.01 sec)



V ďalšom dieli sa naučíme zoskupovať dáta, vyhľadávať text, obmedzovať počet záznamov na výstupe, atď... Je sa na čo tešiť.


Úloha číslo 3

V tejto tretej úlohe ide hlavne o vyskúšanie si nových výrazov!

  • Vyskúšajte si príkaz WHERE rôznymi spôsobmi
  • Použite aj logické operátori AND a OR
  • Skúste si doplniť nejaký záznam do tabuľky, poprípade ho vymazať. Využite pritom aj výraz WHERE
  • A nakoniec si pohrajte s príkazom COUNT

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

2 názory  —  2 nové  
Hlasování bylo ukončeno    
0 hlasů
Google
Autor je študentom Masarykovej univerzity v Brne s odborom Aplikovaná Informatika. Medzi zaľuby patrí práca s PHP & MySQL, JAVA a práca s hudbou.

Nové články

Obrázek ke článku JIC otevírá největší digitální dílnu pro veřejnost v České republice

JIC otevírá největší digitální dílnu pro veřejnost v České republice

JIC otevírá první nonstop veřejně dostupnou digitální dílnu světového formátu s vybavením za 3 miliony korun. Dílnu může využívat po registraci kdokoliv. V  prostorách vzniknou prototypy produktů místních startupů, projekty kutilů a studentů i umělecká díla. Cílem dílny je zpřístupnit veřejnosti drahé přístroje a přitáhnout více podnikavých lidí k technickým oborům.

Reklama
Reklama
Obrázek ke článku Nový IT hráč na českém trhu

Nový IT hráč na českém trhu

V roce 2015 otevřela v Praze na Pankráci v budově City Tower své kanceláře společnost EPAM Systems (NYSE:EPAM), jejíž centrála se nachází v USA. Společnost byla založená v roce 1993 a od té doby prošla velkým vývojem a stále roste.

Obrázek ke článku České Radiokomunikace opět hledají nejlepší nápady pro internet věcí

České Radiokomunikace opět hledají nejlepší nápady pro internet věcí

České Radiokomunikace (CRA) pořádají druhý ročník CRA IoT Hackathonů. Zájemci z řad vývojářů a fanoušků moderních technologií mohou změřit své síly a během jediného dne sestrojit co nejzajímavější funkční prototyp zařízení, které bude komunikovat prostřednictvím sítě LoRa. CRA IoT Hackathony se letos uskuteční ve dvou fázích, na jaře a na podzim, v různých městech České republiky. Jarní běh se odstartuje 31. března v Brně a 7. dubna v Praze.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý