SQL - vstavané funkcie: Rozdiel medzi revíziami

Z Kiwiki
Skočit na navigaci Skočit na vyhledávání
Riadok 197: Riadok 197:
 
Dátum vo formáte RRRR-MM-DD, medzi 1000-01-01 a 9999-12-31. Napríklad, 30. decembra 1973 by sa uloží ako 1973-12-30.  
 
Dátum vo formáte RRRR-MM-DD, medzi 1000-01-01 a 9999-12-31. Napríklad, 30. decembra 1973 by sa uloží ako 1973-12-30.  
  
SELECT DATE<br> výsledok&nbsp;: 2003-12-31<br><br> '''DAY'''  
+
Príklad:
 +
<source lang="sql">
 +
SELECT DATE
 +
</source>
 +
 
 +
Výsledok:
 +
 
 +
<span style="background-color:yellow">2003-12-31</span>
 +
 
 +
 
 +
'''DAY'''  
  
 
<br> '''DAYNAME'''  
 
<br> '''DAYNAME'''  
Riadok 215: Riadok 225:
 
<br> '''WEEK'''  
 
<br> '''WEEK'''  
  
<br> '''YEAR'''  
+
<br> '''YEAR'''
  
 
== Šifrovacie a komprimačné  ==
 
== Šifrovacie a komprimačné  ==

Verzia zo dňa a času 14:36, 27. október 2010

Imbox draft.png
Toto je projekt, na ktorom sa ešte stále pracuje!!

Aj keď sú v tomto dokumente použiteľné informácie, ešte nie je dokončený. Svoje návrhy môžete vyjadriť v diskusii o tejto stránke.

Databázový systém mySQL podporuje obsahuje vstavané funkcie, často nazývané aj agregačné funkcie. Tieto funkcie môžeme rozdeliť do skupín podľa ich zamerania:

  • Agregačné
  • Matematické
  • Textové
  • Štatistické
  • Dátumové
  • Šifrovacie a komprimačné

Agregačné funkcie

Agregačné funkcie vykonávajú nad stĺpcami tabuľky matematické operácie.

COUNT()

Funkcia COUNT slúži na výpočet počtu záznamov v SQL dotaze.

Úloha: Zisti, koľko je v tabuľke city miest s kódom krajiny SVK (teda na Slovensku)

  SELECT COUNT(*) FROM city WHERE CountryCode = "SVK"

Výsledok: COUNT(*): 3

Vylepšená verzia, pre prehľadnejšie čítanie výsledku:

  SELECT COUNT(*) AS pocet FROM city WHERE CountryCode = "SVK"

Výsledok: pocet: 3

MAX() a MIN()

Funkcia MAX(), resp. MIN() slúži na zistenie maximálnej, resp. minimálnej hodnoty z určitej množiny hodnôt.


Úloha: Zisti, ktoré mesto má najväčšiu populáciu.

Riešenie: Úlohu si rozdelíme na 2 časti:

  1. Zistenie maximálnej populácie z tabuľky miest
  2. Výber mesta s touto populáciou. Pre riešenie tejto úlohy použijeme vnorený príkaz SELECT

Podúloha 1:

 SELECT MAX(Population) FROM city

Výsledok: 10500000 Podúloha 2:

 SELECT *  FROM city where Population=
     (SELECT MAX(Population) FROM city)

Výsledok:

AVG()

Funkcia AVG() počíta aritmetický priemet množiny hodnôt.


Úloha: Aká je priemerná populácia na Slovensku?

   SELECT AVG(population) FROM city where CountryCode="SVK"

Výsledok: AVG(population): 261381.0000

SUM()

Funkcia SUM() počíta súčet hodnôt danej množiny hodnôt.


Úloha: Aký je súčet obyvateľov miest na Slovensku?

   SELECT SUM(population) FROM city where CountryCode="SVK"

Výsledok: SUM(population): 784143

STD()

Funkcia SUM() počíta štandardnú odchýlku množiny hodnôt.


Úloha: Aká je štandardná odchýlka počtu obyvateľov v mestách Českej republiky?

   SELECT STD(population) FROM city where CountryCode="CZE"

Výsledok: STD(population): 321564.4992

Matematické funkcie

ABS


SIN


COS


CEIL


EXP


FLOOR


FORMAT


LOG


LOG10


PI


POW


ROUND


SQRT


TAN


RAND

Textové funkcie

CHAR

CONCAT

FIELD

LOWER

UPPER


LTRIM(str)

Zo začiatku reťazca str odstráni nečitateľné znaky (medzery).

Príklad:

   SELECT LTRIM('   ahoj DBS')

Výsledok:

ahoj DBS


RTRIM(str)

Z konca reťazca str odstráni nečitateľné znaky (medzery).

Príklad:

   SELECT RTRIM('ahoj DBS   ')

Výsledok:

ahoj DBS


TRIM

Zo začiatku a konca reťazca str odstráni nečitateľné znaky (medzery).

Príklad:

   SELECT TRIM('   ahoj DBS    ')

Výsledok:

ahoj DBS

Dátumové funkcie

ADDDATE


ADDTIME


CURRDATE


CURTIME


DATE

Dátum vo formáte RRRR-MM-DD, medzi 1000-01-01 a 9999-12-31. Napríklad, 30. decembra 1973 by sa uloží ako 1973-12-30.

Príklad:

SELECT DATE

Výsledok:

2003-12-31


DAY


DAYNAME


DAYOFWEEK


DAYOFMONTH


DAYOFYEAR


HOUR


NOW


SYSDATE


WEEK


YEAR

Šifrovacie a komprimačné

AES_ENCRYPT( nezasifrovany_text , kluc )

Funkcie AES_ENCRYPT() a AES_DECRYPT() šifrujú a dešifrujú dáta pomocou oficiálneho algoritmu AES(Advanced Encryption Standard), ktorý bol predtým známy ako "Rijndael." Dĺžka šifrovacieho kľúča je 128 bitov. Dĺžku kľúča sa môže predĺžiť až na 256 bitov. Vybrali sme si 128 kúskov, pretože to je oveľa rýchlejšie a je dostatočne zabezpečený pre väčšinu účelov.

   insert into test (text,zasifrovane,heslo) values ("kiwiki",AES_ENCRYPT("kiwiki","123456789"),"1234567789")

Výsledok:

Sql AES ENCRYPT.png

AES_DECRYPT( zasifrovany_text , kluc)

Táto funkcia dešifruje dáta pomocou šifrovacieho algoritmus AES (Advanced Encryption Standard)

   SELECT text, AES_DECRYPT(zasifrovane,"123456789") as rozsifrovane ,heslo from test

Výsledok:

Sql AES DECRYPT.png

COMPRESS( str ), UNCOMPRESS( str )

Komprimuje/dekomprimuje reťazec a vráti výsledok ako binárny reťazec. Táto funkcia vyžaduje konfigur8ciu MySQL servara tak, aby boli zostavený s kompresnou knižnicu ako zlib. V opačnom prípade je návratová hodnota vždy NULL. Komprimovaný reťazec môže byť nekomprimované s UNCOMPRESS().

   INSERT INTO test (text,zasifrovane) VALUES ("kiwiki",COMPRESS("kiwiki"))

Výsledok:

Sql compress.png


   SELECT id, text, UNCOMPRESS(zasifrovane) AS dekomprimovane FROM test

Výsledok:

Sql uncompress.png


ENCODE()


DECODE()


DES_DECRYPT( text, [kluc]), DES_ENCRYPT(text , kluc)

Funkcie DES_ENCRYPT() a DES_DECRYPT() šifrujú a dešifrujú dáta pomocou oficiálneho algoritmu DES. Použitie je podobné ako pri funkciách aes_decript a aes_encrypt.


MD5()


SHA1(), SHA()


PASSWORD()

Na základe vtupného textu vypočíta heslo. Táto funkcia je použitá na generovanie hesiel v databáze mysql (tabuľka users).

  SELECT PASSWORD('kiwiki');

Výsledok:

*D94D4484B4D4060225F91D28D7BB131F917F760C

Zdroje a odkazy