Jazyk SQL (Structured Query Language)
Jazyk SQL bol vytvorený za účelom práce s údajmi v databázach. Môžeme ho rozdeliť do následujúcich troch skupín:
Data Definition Language DDL
Pomocou týchto príkazov môžeme definovať, vytvárať, meniť a rušiť rôzne databázové štruktúry, akými sú napr. databázové tabuľky, indexy, triggery, uložené procedúry ...
| CREATE DATABASE | CREATE VIEW | DROP SEQUENCE |
| CREATE TABLE | ALTER VIEW | CREATE PROCEDURE |
| ALTER TABLE | DROP VIEW | DROP PROCEDURE |
| DROP TABLE | DROP INDEX | CREATE TRIGGER |
| CREATE INDEX | CREATE SEQUENCE | DROP TRIGGER |
| DROP INDEX | ALTER SEQUENCE |
Data Manipulation Language DML
Príkazy pre manipuláciu s údajmi ako napr.: vkladanie, aktualizácia, mazanie a príkaz SELECT.
| SELECT | UPDATE |
| INSERT | DELETE |
Data Control Language DCL
Táto skupina príkazov záhŕňa príkazy pre údržbu a riadenie databázy.
| CREATE ROLE | GRANT |
| ALTER ROLE | REVOKE |
| DROP ROLE | REVOKE ALL ON |
Tvorba prázdnej atribútovej tabuľky:
(
zsj_id integer,
plyn integer,
elektrina integer,
kvapalne integer,
pevne integer,
solarna integer,
iny integer,
bez integer,
nezisteny integer,
spolu integer
);
Import a export údajov
Skôr ako je možné pristúpiť k importovaniu údajov typu .txt alebo .csv je
potrebné mať vytvorenú prázdnu atribútovú tabuľku do ktorej bude možné údaje vložiť.
testovacie údaje: byty_vykurovanie
1) IMPORT
COPY byty_vykurovanie
FROM '/home/user/udaje/byty_vykurovanie.csv' WITH CSV DELIMITER ',' HEADER;
COPY tabulka FROM subor.txt DELIMITER '|' NULL AS '';
2) EXPORT
COPY (SELECT * FROM byty_vykurovanie) TO /tabulka_export.csv WITH DELIMITER '|' CSV HEADER
VYBRANÉ PRÍKAZY NA DOPYTOVANIE A MODIFIKOVANIE TABUĽKY:
SELECT DISTINCT stlpec FROM tabulka WHERE stlpec LIKE '%ek';
UPDATE tabulka SET stlpec='nova hodnota' WHERE id=3;
ALTER TABLE tabulka ADD/DROP COLUMN poloha POINT;
ALTER TABLE tabulka ALTER COLUMN poloha TYPE varchar(30);
DELETE FROM tabulka WHERE id=3;
CREATE VIEW AS SELECT * FROM tabulka WHERE nejaka_podmienka;
Operátory porovnania
| Operator | Description |
|---|---|
| < | less than |
| > | greater than |
| <= | less than or equal to |
| >= | greater than or equal to |
| = | equal |
| <> or != | not equal |
| IS NULL | Kde NULL reprezentuje neznámu hodnotu |
| IS NOT NULL | výraz nieje neznámej hodnoty |
- a BETWEEN x AND y // je to isté ako a >= x AND a <= y
- a NOT BETWEEN x AND y // je to isté ako a < x AND a > y
Logické operátory
- AND
- OR
- NOT
Matematické operátory
| Operátor | Popis | Príklad | Výsledok |
|---|---|---|---|
| + | addition | 2 + 3 | 5 |
| - | subtraction | 2 - 3 | -1 |
| * | multiplication | 2 * 3 | 6 |
| / | division (integer division truncates the result) | 4 / 2 | 2 |
| % | modulo (remainder) | 5 % 4 | 1 |
| ^ | exponentiation | 2.0 ^ 3.0 | 8 |
| |/ | square root | |/ 25.0 | 5 |
| ||/ | cube root | ||/ 27.0 | 3 |
| ! | factorial | 5 ! | 120 |
| !! | factorial (prefix operator) | !! 5 | 120 |
| @ | absolute value | @ -5.0 | 5 |
| & | bitwise AND | 91 & 15 | 11 |
| | | bitwise OR | 32 | 3 | 35 |
| # | bitwise XOR | 17 # 5 | 20 |
| ~ | bitwise NOT | ~1 | -2 |
| << | bitwise shift left | 1 << 4 | 16 |
| >> | bitwise shift right | 8 >> 2 | 2 |
Prednosť operátorov
SELECT (1+2)*3 AS vypocet;
