SQL. přednáška č.? + 1 1/90

Rozměr: px
Začít zobrazení ze stránky:

Download "SQL. přednáška č.? + 1 1/90"

Transkript

1 SQL přednáška č.? + 1 1/90

2 Poznámka CHECK a FOREIGN KEY integritní omezení jsou si podobná v tom, že kontrolují hodnoty vkládané do atributu Rozdíl spočívá ve způsobu, kterým se získává množina přípustných hodnot. FOREIGN KEY získává tento seznam z jiné tabulky CHECK má přípustné hodnoty vymezeny logickou podmínkou 2

3 Otázka Relace: PRODUKT (ID, BARVA, CENA)?BARVA(ID_BARVA, NAZEV)?BARVA(NAZEV) + ON UPDATE CASCADE kterou variantu použít? první nebude propagovat změny v názvu barvy do tabulky PRODUKT druhá nebude vyžadovat spojení v případě, že bude třeba zjistit barvu produktu 3

4 Změna a smazaní relace/atributu ALTER TABLE [ database_name. [ schema_name ]. schema_name. ] table_name { ALTER COLUMN column_name { [ type_schema_name. ] type_name [ ( { precision [, scale ] max xml_schema_collection } ) ] [ NULL NOT NULL ] [ COLLATE collation_name ] {ADD DROP } { ROWGUIDCOL PERSISTED } } [ WITH { CHECK NOCHECK } ] ADD {<column_definition> <computed_column_definition> < table_constraint> } [,...n ] DROP { [ CONSTRAINT ] constraint_name [ WITH ( <drop_clustered_constraint_option> [,...n ] ) ] COLUMN column_name } [,...n ] [ WITH { CHECK NOCHECK } ] { CHECK NOCHECK } CONSTRAINT { ALL constraint_name [,...n ] } { ENABLE DISABLE } TRIGGER { ALL trigger_name [,...n ] } SWITCH [ PARTITION source_partition_number_expression ] TO [ schema_name. ] target_table [ PARTITION target_partition_number_expression ] } [ ; ] <drop_clustered_constraint_option> ::= { MAXDOP = max_degree_of_parallelism ONLINE = {ON OFF } MOVE TO { partition_scheme_name ( column_name ) filegroup "default"} } 4

5 Změna a smazaní relace/atributu ALTER TABLE jméno_relace {ADD DROP} atribut datový_typ [NULL,..] ADD přidání nového atributu DROP odebrání exitujícího atributu z relace ALTER TABLE osoby ADD pocet_deti integer ALTER TABLE osoby DROP pocet_deti DROP TABLE jmeno_relace DROP TABLE osoby 5

6 Příklad, přidání atributu CREATE TABLE doc ( column_a INT ) ; ALTER TABLE doc ADD column_b VARCHAR(20); 6

7 Odebrání atributu CREATE TABLE doc ( column_a INT, column_b VARCHAR(20) ) ; ALTER TABLE doc DROP COLUMN column_b ; 7

8 Změna typu atributu CREATE TABLE doc ( column_a INT ) ; ALTER TABLE doc ALTER COLUMN column_a DECIMAL (5, 2) ; 8

9 Přidání IO CREATE TABLE doc ( column_a INT ) ; ALTER TABLE doc WITH NOCHECK ADD CONSTRAINT exd_check CHECK (column_a > 1) ; WITH NOCHECK zajistí, že při změně se nebudou kontrolovat existující záznamy proti novému CHECK 9

10 Odebrání IO CREATE TABLE doc ( column_a INT CONSTRAINT my_constraint UNIQUE) ; ALTER TABLE doc DROP CONSTRAINT my_constraint ; 10

11 Definice Indexů CREATE [UNIQUE] [CLUSTERED NONCLUSTERED] INDEX jméno_indexu ON jméno_relace (jméno_atributu [uspořádání] [, jméno_atributu [uspořádání]] ) CREATE UNIQUE INDEX rc ON osoby (rodne_cislo) CREATE INDEX jp ON osoby (jmeno,prijmeni) 11

12 Indexy II. CLUSTERED Pouze jeden index v tabulce lze definovat jako clustered Záznamy v primárním souboru jsou pak seřazeny podle toho sloupce (sloupců) NONCLUSTERED Soubor není na tomto atributu setříděn QNIQUE Každý atribut bude unikátní (porovnej s definicí primárního klíče) Klausule PRIMARY KEY může být pouze jednou v definici relace 12

13 CREATE DOMAIN Jedná se vlastně o vytvoření nové množiny hodnot, kterou pak lze použít v definici tabulek Create domain "rc" Char(13) Default /0000; 13

14 Příklady- PostgreSQL Create table "Osoba" ( "id_osoba" Integer NOT NULL, "jmeno" Varchar(35) NOT NULL Default neni zadano, "prijmeni" Varchar(35) NOT NULL Default neni zadano, "rodne_cislo" Char(13) NOT NULL Default /0000, primary key ("id_osoba") ) 14

15 ER -> relační databáze Jméno RC Plat Zaměstnanci CREATE TABLE Zamestnanci ( RC CHAR(12), Jmeno CHAR(30), Plat Integer, PRIMARY KEY (RC) ); 15

16 Create table "material" ( "id_material" Integer NOT NULL, "nazev" Varchar(20) NOT NULL Default ----, "pocet" Integer NOT NULL Default 0 Check (pocet>=0), primary key ("id_material") ) Create table "objednavka" ( "kod" Integer NOT NULL, "pocet_kusu" Char(20) NOT NULL Check (pocet_kusu<=(select pocet FROM material WHERE objednavka.id_material = material.id_material)), "id_material" Integer NOT NULL, primary key ("kod") ) Alter table "objednavka" add foreign key ("id_material") references "material" ("id_material") on update cascade on delete cascade; 16

17 17 příklad

18 Create table [Sailors] ( [sid] Integer NOT NULL, [sname] Varchar(32) NULL, [raiting] Integer NOT NULL CHECK (raiting>=1 AND raiting<=10), [age] Real NOT NULL CHECK (age>18), Primary Key ([sid]), ) Create table [Boats] ( [bid] Integer NOT NULL, [bname] Char(10) NOT NULL, [color] Char(10) NOT NULL, [bimage] Image NULL, Primary Key ([bid]) ) Create table [Reservers] ( [sid] Integer NOT NULL, [bid] Integer NOT NULL, [day] Datetime NOT NULL, foreign key([bid]) references [Boats] ([bid]), foreign key([sid]) references [Sailors] ([sid]), Primary Key ([sid],[bid]), CHECK ( interlake <> SELECT Boats.name FROM Boats WHERE Boats.bid=Reservers.bid) ) 18

19 Self relace Create table "Dokument" ( "cislo_dokumentu" Integer NOT NULL, "cislo_dokumentu_fk" Integer NOT NULL, "text" Text, primary key ("cislo_dokumentu"), foreign key ("cislo_dokumentu_fk") references "Dokument" ("cislo_dokumentu") on update restrict on delete restrict ) 19

20 Create table "Osoba"( ) Create table "objednavka"( ) Create table "objednavky"( "id_osoba" Integer NOT NULL, "kod" Integer NOT NULL, "datum" Date, primary key ("id_osoba","kod") ) Alter table "objednavky" add foreign key ("id_osoba") references "Osoba" ("id_osoba") on update cascade on delete cascade ; Alter table "objednavky" add foreign key ("kod") references "objednavka" ("kod") on update cascade on delete cascade ; 20

21 SQL II. SELECT, INSERT, DELETE, UPDATE, příklady přednáška č

22 Spouště DML Řízení transakcí Vložené a dynamické SQL SQL DDL Integritní omezení Bezpečnost Přístupová práva 22

23 Úvod Doposud jsme provedli analýzu Návrh Implementaci (tedy vytvoření DB a souvisejících objektů) A teď chceme napsat aplikaci, která bude s daty v DB pracovat 23

24 Co potřebujeme? Data jsou v relačním modelu uložena v relacích (tabulkách) Vzhledem k nutnosti dodržovat normální formy, jsou relace dokomponovány Dekompozice jinými slovy znamená, že data nejsou v jedná tabulce. 24

25 Konstruktor SELECT SELECT [DISTINCT ALL] {* jméno_atributu1 [,jméno_atributu2] } FROM název_relace[,název_relace2] [WHERE podmínka] [GROUP BY atributy [HAVING podmínka_agregace]] [ORDER BY jméno_atributu1[,jméno_atributu2] ] 25

26 Manipulace dat v SQL Sémantika příkazu SELECT vytvoří se kartézský součin z relací FROM vyhodnotí se podmínka WHERE rozdělení do podskupin GROUP BY relace se omezí dle HAVING Uspořádá se pomocí ORDER BY 26

27 SELECT DISTINCT 27

28 Manipulace s daty v SQL PROJEKCE SELECT jmeno FROM osoby KARTÉZKÝ SOUČIN SELECT * FROM osoby,byty SELEKCE SELECT RC,jmeno FROM osoby WHERE jmeno= jan SPOJENÍ SELECT jmeno FROM osoby,byty WHERE osoby.rc=byty.rc 28

29 Spojení tabulek Jaká je nosnost automobilu s spz A ? Je třeba znovu složit dekomponované tabulky, abychom mohli tuto informaci dostat Spz Jméno Typ A Karel 1 L Petr 1 L Jana 2 L Eva 2 L Jan 2 Typ Nosnost x y z

30 Spojení tabulek pomocí SQL SELECT nosnost,spz FROM Auta, Nosnosti WHERE Auta.Typ = Nosnosti.Typ AND Spz= A

31 Co to udělá? Nejprve např. spojíme tabulky Nosnosti a Auta Spz Typ Nosnost x y z A L L L L

32 Co to udělá? Pak vybereme řádky, které splňují podmínku na spz= A Spz Typ Nosnost x y z A

33 Co to udělá? Následně vybereme požadované atributy nosnost a spz Spz Nosnost A

34 Kolik je řádků bude mít kartézký součin Auta = 5 tabulek? Nosnosti = 2 Auta*Nosnosti == 2*5 = 10 Spz Jméno Typ A Karel 1 L Petr 1 L Jana 2 L Eva 2 L Jan 2 Typ Nosnost x y z

35 Spz Typ Nosnost x y z A A L L L L L L L L

36 Proto je nutné říci, který atribut je určen pro spojení Proto SELECT nosnost,spz FROM Auta, Nosnosti WHERE Auta.Typ= Nosnosti.Typ AND Spz= A

37 Kartézský součin cid jmeno vek did kancelar patro 1 karel 23 2 petr a e 4 cid jmeno vek did kancelar patro 1 karel a 2 2 petr e 4 1 karel e 4 2 petr a 2 37

38 Spojení tabulek pomocí SQL Zadání: najdi režiséry jejichž filmy jsou rezervovány Předpokládejme existenci tabulek FILMY a REZERVACE SELECT DISTINCT reziser FROM Filmy, Rezervace WHERE Filmy.jmeno_f=Rezervace.jmeno_f 38

39 Varianty předchozího SELECT Rezervace.*,Filmy.* FROM Filmy, Rezervace WHERE Filmy.jmeno_f=Rezervace.jmeno_f SELECT DISTINCT Filmy.reziser FROM Filmy, Rezervace WHERE Filmy.jmeno_f=Rezervace.jmeno_f 39

40 Příklad na kartézský součin cid jmeno vek did kancelar patro 1 karel 23 2 petr a e 4 SELECT * FROM Clovek, Kancelar 40

41 Kartézský součin cid jmeno vek did kancelar patro 1 karel 23 2 petr a e 4 cid jmeno vek did kancelar patro 1 karel a 2 2 petr e 4 1 karel e 4 2 petr a 2 41

42 Spojení tabulek pomocí konstruktu JOIN SELECT produkt_c AS jmeno FROM tprodukty JOIN tceny ON (tprodukty.produkt_id=tceny.cena_pr) WHERE produkt_e LIKE %product% ORDER BY tprodukty.produkt_e UNION (spojení) INTERSECT(průnik)* EXCEPT(rozdíl)* Pozn. )* často není DB podporováno 42

43 Cross join T1 CROSS JOIN T2 Ekvivalent kartézského součinu Pokud budeme spojovat dvě tabulky o velikostech M a N, pak výsledná tabulka bude mít M.N řádků 43

44 Vnitřní spojení INNER JOIN Je to výchozí hodnota pro JOIN Ve výsledku budou jen ty řádky, které mají spojované tabulky společné 44

45 Vnější spojení OUTER JOIN Spojované tabulky mohou mít i různé hodnoty v řádcích. Kde hodnota nebyla dolní se automatický NULL 45

46 LEFT OUTER JOIN T1 LEFT OUTER JOIN T2 Provede se vnitřní spojení Pak se vezmou řádky z tabulky vlevo (tabulka T1) a do odpovídajících atributů tabulky pravé (T2) se doplní NULL 46

47 RIGHT OUTER JOIN T1 RIGHT OUTER JOIN T2 Provede se vnitřní spojení Pak se vezmou řádky z tabulky vpravo (T2) a do odpovídajících atributů tabulky levé (T1) se doplní NULL 47

48 FULL OUTER JOIN Provede se vnitřní spojení Pak se provede LEFT Následně RIGHT 48

49 Příklady t1 num name a 2 b 3 c t2 num value xxx 3 yyy 5 zzz 49

50 SELECT * FROM t1 CROSS JOIN t2; t1 num name a 2 b 3 c t2 num value xxx 3 yyy 5 zzz num name num value a 1 xxx 1 a 3 yyy 1 a 5 zzz 2 b 1 xxx 2 b 3 yyy 2 b 5 zzz 3 c 1 xxx 3 c 3 yyy 3 c 5 zzz (9 rows) 50

51 SELECT * FROM t1 INNER JOIN t2 ON t1.num = t2.num; t1 num name a 2 b 3 c t2 num value xxx 3 yyy 5 zzz num name num value a 1 xxx 3 c 3 yyy 51

52 SELECT * FROM t1 INNER JOIN t2 USING (num); t1 num name a 2 b 3 c t2 num value xxx 3 yyy 5 zzz num name value a xxx 3 c yyy 52

53 SELECT * FROM t1 NATURAL INNER JOIN t2; t1 num name a 2 b 3 c t2 num value xxx 3 yyy 5 zzz num name value a xxx 3 c yyy 53

54 SELECT * FROM t1 LEFT JOIN t2 ON t1.num = t2.num; t1 num name a 2 b 3 c t2 num value xxx 3 yyy 5 zzz num name num value a 1 xxx 2 b NULL NULL 3 c 3 yyy 54

55 SELECT * FROM t1 RIGHT JOIN t2 ON t1.num = t2.num; t1 num name a 2 b 3 c t2 num value xxx 3 yyy 5 zzz num name num value a 1 xxx 3 c 3 yyy NULL NULL 5 zzz 55

56 Artimetika a agregační funkce Aritmetické funkce +, -, *, / Agregační funkce COUNT, SUM, MAX, MIN, AVG 56

57 Aritmetika SELECT did,cena/23.45, kusu*23 FROM Nakup X, Zakaznik Y WHERE Y.jmeno= Karel Malina AND X.sid=34; 57

58 Agregační funkce SELECT Count(*) AS pocet FROM Zakaznik; SELECT Count(did) FROM Zakaznik; Celkový počet zakazníků SELECT SUM(DISTINCT jmeno_f) FROM Rezervace; Kolik je rezervováno filmů (jeden film může mít více rezervací) 58

59 Celková suma peněz ve výpůjčkách Karla SELECT SUM(X.cena) FROM Vypujcky X, Zakaznici Y WHERE Y.Jmeno= Karel AND X.cid=y.cid Jaká je průměrná cena v tabulce výpůjčky SELECT AVG(cena) FROM Vypujcky 59

60 GROUP BY Konstrukt GROUP BY a HAVING MIN se bude používat až na skupiny vytvořené pomocí GROUP BY SELECT S.rating, MIN(S.age) AS minage FROM Sailors S WHERE S.age>=18 GROUP BY S.rating HAVING COUNT (*) > 1 60

61 Vyhodnocení příkladu Sid sname rating age 22 Petr Brutus Karel Andy Kuba Horacio Jana Pepa Michala Karolina 3 63 rating minage rating minage

62 Výsledek příkladu rating minage Sid sname rating age 22 Petr Brutus Karel Andy Kuba Horacio Jana Pepa Michala Karolina

63 Množiny v SQL Predikáty: IN, ANY, ALL, SOME, EXISTS 63

64 IN jméno_atributu [ NOT] IN poddotaz Nebo jméno_atributu [ NOT] IN (seznam hodnot) 64

65 Příklady Najděte adresy kin, ve kterých dávají film Kolotoč SELECT adresa FROM Kina WHERE nazev_k IN (SELECT nazev_kina FROM Program WHERE jmeno_f= Kolotoč ); 65

66 Zadání množiny pomocí výčtu SELECT adresa FROM Kina WHERE nazev_k IN ( Kolotoč, Sprcha, Med ); 66

67 Vložené dotazy SELECT jmeno FROM Zakaznici WHERE rc IN ( SELECT rc FROM Rezervace WHERE Rezervace.jmeno_f NOT IN (SELECT F.jmeno FROM Filmy WHERE F.reziser= Sverak ) ); 67

68 Pozn. Chování IN nad prázdnou IN (0) vrací FALSE množinou 68

69 ANY, ALL, SOME SOME == ANY (v SQL92 obě) Najdi zaměstnance, který má plat větší než všichni zaměstnanci z Prahy SELECT did,jmeno FROM Zam WHERE plat > ALL (SELECT Zam.plat FROM Zam WHERE Zam.adresa LIKE %Praha% ); 69

70 Manipulace s množinami p IN A p je prvkem množiny A množinu tvoří výčet nebo SELECT-FROM-WHERE SELECT * FROM osoba,byt WHERE (osoba.rc=byt.rc) AND (byt.ulice IN ( Hálkova, Pražská )) SELECT * FROM osoba,byt WHERE (osoba.rc=byt.rc) AND ( byt.ulice IN ( SELECT * FROM byt WHERE (ulice LIKE H% ))) 70

71 Manipulace dat v SQL Prázdné hodnoty Rozšíření RMD Agregační funkce aplikované na prázdnou množinu vracejí NULL Zakázáno : spojení přes NULL, dotaz bydliste=null, spec.příkaz IS NULL 71

72 Syntaxe INSERT INSERT [LOW_PRIORITY DELAYED HIGH_PRIORITY] [IGNORE] [INTO] tbl_name [(col_name,...)] VALUES ({expr DEFAULT},...),(...),... [ ON DUPLICATE KEY UPDATE col_name=expr,... ] INSERT INTO osoba (jmeno,prijmeni) VALUES ( Jan, Novak ) INSERT INTO osoba SELECT * FROM tab Pozor zde není values 72

73 Syntaxe UPDATE UPDATE [LOW_PRIORITY] [IGNORE] tbl_name SET col_name1=expr1 [, col_name2=expr2...] [WHERE where_definition] [ORDER BY...] [LIMIT row_count] UPDATE osoba SET jmeno= Jan WHERE jmeno= Honza 73

74 Syntaxe DELETE DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM tbl_name [WHERE where_definition] [ORDER BY...] [LIMIT row_count] DELETE FROM osoba WHERE jmeno= Jan 74

75 Definice pohledů Virtuální relace, pohled na aplikaci uživatelskýma očima CREATE VIEW jméno_pohledu [(njméno_atr1[,njméno_atr2]...)] AS SELECT [DISTINCT] {* jméno_atr1[,jméno_atr2]...} FROM jméno_relace1[,jméno_relace2]... [WHERE podmínka1] [WITH CHECK OPTION] [GROUP BY gjméno_atr1[,gjméno_atr2]... [HAVING podmínka2]] [ENABLE UPDATE] CREATE VIEW pohled AS SELECT * FROM t1 WHERE a > 0; DROP VIEW jméno_pohledu; 75

76 Pohledy II. (SQL-92) Logická datová nezávislost rychlost (optimalizátor může používat stále stejný plán) Bezpečnost UPADTE Updatable views pouze nad jednou tabulkou INSERT NULLs kde není definováno -? Co prim. Klíč? WITH CHECK OPTION kontrola, zda bude vložená n-tice vidět v pohledu DELETE 76

77 Ochrana dat Požadavek více uživatelského SŘBD Přístup k relaci(pohledu), definice práv GRANT {ALL {DELETE INSERT SELECT UPDATE [(atribut1[, atribut2] )]} } ON relace TO {PUBLIC uživatel1[,uživatel2] } Odebrání práv REVOKE 77

78 Manipulace dat v SQL Systémový katalog Informace o SŘBD SYSTABLE jméno relace, zakladatele,počet atributů,... SYSCOLUMNS jméno atributu,jméno relace,... SYSINDEXES jméno indexu, jméno relace,... COMMENT Komentáře 78

79 Group By SELECT "column_name1", SUM("column_name2") FROM "table_name" GROUP BY "column_name1" Store_Information store_name Sales Date Los Angeles $1500 Jan San Diego $250 Jan Los Angeles $300 Jan Boston $700 Jan SELECT store_name, SUM(Sales) FROM Store_Information GROUP BY store_name store_name SUM(Sales) Los Angeles $1800 San Diego $250 Boston $700 79

80 Having SELECT "column_name1", SUM("column_name2") FROM "table_name" GROUP BY "column_name1" HAVING (arithmetic function condition) Store_Information store_name Sales Date Los Angeles $1500 Jan San Diego $250 Jan Los Angeles $300 Jan Boston $700 Jan SELECT store_name, SUM(sales) FROM Store_Information GROUP BY store_name HAVING SUM(sales) > 1500 Result: store_name SUM(Sales) Los Angeles $

81 Užitečné odkazy tml tml on/index.html 81

82 SQL III. Stored procedures Triggers

83 Triggers Trigger (spoušť) je procedura která je automaticky spuštěna DBMS jako reakce na specifikovanou akci v databázi Aktivní databáze: DB, která obsahuje definici spouští 83

84 Popis spouště Event (událost) - změna v DB, která vyvolá spuštění Condition (podmínka) dotaz nebo test, který je proveden pokud je spoušť aktivována Action (akce) procedura, která je provedena při spuštění a pokud je splněna podmínka 84

85 85

86 Event (akce) INSERT UPDATE DELETE Nezáleží na to kdo (který uživatel) provede akci Uživatel si není vědom aktivity spouští v DB 86

87 Příklad použití Mějme DB studentů (STUDENT) Mějme dále tabulku obsahující informace o počtu studentů mladších 18 let Při vložení nového záznamu do tabulky STUDENT je aktivována spoušť, která zvýší atribut v tabulce obsahující počet studentů mladších 18 let 87

88 After x before Podle funkce je možné tuto změnu provést před nebo po provedení změn nad tabulkou STUDENT 88

89 Triggers in SQL CREATE TRIGGER init_count BEFORE INSERT ON Students/* event */ DECLARE count INTEGER; BEGIN count:=0; /* action */ END 89

90 CREATE TRIGGER inc_count AFTER INSERT ON Students /* event */ WHEN (new.age<18) /* condition */ FOR EACH ROW BEGIN /* action */ count:=count+1; END 90

91 Jak zjistím, kterou hodnotou je v DB pracováno? New Označuje nově vkládanou/upravovanou n-tici (řádek) do relace v DB Old Pokud byla hodnota n-tice v DB měněna pak se lze pomocí new odkázat na nově vložená data Old data před změnou 91

92 Trigery x Omezení Spouště slouží v DB k zajištění konzistence dat v DB IO slouží ke stejnému účelu, zachování konzistenci dat vždy Spouště jsou aktivovány pouze na určité stimuly 92

93 Příklad, kdy je lépe použít Trigger Mějme relaci Objednavky (oid,počet,idzakaznika, jednotkovacena) Při založení objednávky jsou první tři atributy vyplněny zákazníkem (případně prodavačem na pokladně) Atribut jednotkovacena je vyplněn podle jiné relace produkty 93

94 Atribut jednotkovacena je však nutné vyplnit, aby byla objednávka kompletní! Pokud by nebyla uvedena, pak by při pozdější změně (např. sleva), byla změněna i ve všech objednávkách již uzavřených 94

95 Napíšeme trigger, který nám tuto hodnotu z tabulku produkty zjistí a vloží do tabulky objednávky Je to vhodné vzhledem k ušetření práce prodavače a zároveň to minimalizuje možnost vzniku chyby při vkládání dat a tím pádem i vzniku nekonzistence v DB 95

96 Mějme dále za úkol provést ještě další kontroly Například při platbě chtějme kontrolovat, zda-li celková cena není větší než, zůstatek na účtu zákazníka To se dá provést pomocí triggeru, ale i CHECK 96

97 Nicméně použití triggeru nám umožní implementovat i složitější kontrolní mechanizmy Např. můžeme dovolit zákazníkovi překročit jeho limit účtu o ne více než 10%, pokud má zákazník u naší společnosti záznam déle než 1 rok. Dále pak můžeme požadovat přidání zákazníka do tabulky pro zvýšení limitu platby 97

98 Condition (podmínka) true/false statement (věk>18) Dotaz Pokud dotaz vrátí neprázdnou množinu jako výsledek, pak odpovídá TRUE Jinak FALSE 98

99 SQL Oracle syntax CREATE [OR REPLACE] TRIGGER <trigger_name> {BEFORE AFTER} {INSERT DELETE UPDATE} ON <table_name> [REFERENCING [NEW AS <new_row_name>] [OLD AS <old_row_name>]] [FOR EACH ROW [WHEN (<trigger_condition>)]] <trigger_body> 99

100 Trigger granularita FOR EACH ROW Provede se tolikrát, kolik je řádek v množině ovlivněných záznamů. Pokud je třeba odkazovat/používat konkrétní řádku/řádky z množiny ovlivněných záznamů, pak použít FOR EACH ROW. Příklad: pokud chceme porovnávat hodnoty nově vložených a starých záznamů v případě AFTER UPDATE triggeru. FOR EACH STATEMENT Provede se jednou pro celý trigger/událost. Pokud je množina ovlivněných záznamů prázdná (např. pokud není splněná podmínka pro UPDATE, DELELE, či INSERT), pak FOR EACH ROW trigger se neprovede vůbec FOR EACH STATEMENT trigger se spustí/provede. 100

101 Příkladudržování počtu zaměstnanců pomocí FOR EACH ROW CREATE TRIGGER NEW_HIRED AFTER INSERT ON EMPLOYEE FOR EACH ROW UPDATE COMPANY_STATS SET NBEMP = NBEMP

102 To samé s FOR EACH STATEMENT CREATE TRIGGER NEW_HIRED AFTER INSERT ON EMPLOYEE REFERENCING NEW_TABLE AS NEWEMPS FOR EACH STATEMENT UPDATE COMPANY_STATS SET NBEMP = NBEMP + (SELECT COUNT(*) FROM NEWEMPS) 102

103 Aktivace Triggeru BEFORE, AFTER aktivaci/provedení spouště. Například, aktivace následují spouště je po (AFTER) provedení operace INSERT nad tabulkou employee 103

104 CREATE TRIGGER NEW_HIRE AFTER INSERT ON EMPLOYEE FOR EACH ROW UPDATE COMPANY_STATS SET NBEMP = NBEMP

105 Before Pokud je jako čas aktivace zvoleno BEFORE, akce spouště jsou aktivovány pro každý řádek ovlivněných záznamů před provedení vlastního dotazu nad databází. Z toho vyplývá, že tabulka, nad kterou se provádí dotaz, bude modifikována až po provedení všech operací BEFORE spouště. Pozn. BEFORE spoušť musí mít granularitu FOR EACH ROW. 105

106 After Akce spouště jsou aktivovány for each row v množině ovlivněných záznamů nebo pro daný příkaz (záleží na granularitě spouště). Spoušť je aktivována až po provedení všech kontrol integritních omezení, které může spoušť (akce ve spoušti) ovlivnit. Pozn. AFTER spouště mohou mít granularitu FOR EACH ROW FOR EACH STATEMENT. 106

107 107

108 Pokud jsou nad tabulkou definovány jak before tak i after spouště, pak se jako první provedou všechny before spouště První spoušť, která je spuštěna vezme jako vstup množinu záznamů, které budou ovlivněný dotazem (UPDATE, INSERT, DELETE) a provede veškeré změny definované v rámci spouště. Výstup první before spouště je pak vstupem následující before spouště. Jakmile jsou aktivovány a dokončeny všechny before spouště, jsou všechny změny provedeny na databázových objektech (včetně vlastního dotazu co spoušť aktivoval) Následně jsou aktivovány všechny after spouště asociované s danou akcí. After spouště pak mohou modifikovat stejnou/jinou tabulku, mohou také spouštět externí akce (poslat ) 108

109 Použití Before BEFORE spouště jsou jakýmsi rozšířením systém integritních omezení. Používají se pro: Provedení validace vstupních dat, Automatické generován hodnot pro nově vkládané/modifikované záznamy Čtení záznamů z odkazovaných tabulek pro ověření referencí. BEFORE spouště nejsou používány pro další modifikace databázových objektů, protože jsou aktivovány před provedení změn vlastním dotazem a tedy jsou aktivovány před kontrolou integritních omezení 109

110 Použití After AFTER trigery mohou být chápány jako modul aplikační logiky který je proveden jako odezva na určitou událost v DB. AFTER trigery vždy pracují s db, která je v konzistetním stavu. Jsou spouštěny až po kontrole IO. Např: Spouštění operací jako odezvu na upravující operace v db Operace mimo databázi, např. spouštění alarmů, externích programů atd. Akce mimo db nejsou pod kontrolou db mechanismů pro rollback 110

111 Omezení Before Before trigery nemohou obsahovat následující operace v SQL příkazech svého těla: UPDATE DELETE INSERT 111

112 Příklad CREATE TABLE T4 (a INTEGER, b CHAR(10)); CREATE TABLE T5 (c CHAR(10), d INTEGER); Vytvoříme trigger, který vloží záznam do tabulky T5 pokud je vložen záznam do T4. Triger zkontroluje, zda-li nově vložený záznam má první složku 10 nebo méně a pokud ano, tak vloží reverzní záznam do T5: CREATE TRIGGER trig1 AFTER INSERT ON T4 REFERENCING NEW AS newrow FOR EACH ROW WHEN (newrow.a <= 10) BEGIN INSERT INTO T5 VALUES(newRow.b, newrow.a); END trig1; 112

113 MySQL mysql> delimiter // mysql> CREATE TRIGGER upd_check BEFORE UPDATE ON account FOR EACH ROW BEGIN IF NEW.amount < 0 THEN SET NEW.amount = 0; ELSEIF NEW.amount > 100 THEN SET NEW.amount = 100; END IF; END;// mysql> delimiter ; 113

114 CREATE TABLE test1(a1 INT); CREATE TABLE test2(a2 INT); CREATE TABLE test3(a3 INT NOT NULL AUTO_INCREMENT PRIMARY KEY); CREATE TABLE test4( a4 INT NOT NULL AUTO_INCREMENT PRIMARY KEY, b4 INT DEFAULT 0 ); DELIMITER CREATE TRIGGER testref AFTER INSERT ON test1 FOR EACH ROW BEGIN INSERT INTO test2 (a2) VALUES NEW.a1; DELETE FROM test3 WHERE a3 = NEW.a1; UPDATE test4 SET b4 = b4 + 1 WHERE a4 = NEW.a1; END; DELIMITER ; INSERT INTO test3 (a3) VALUES (NULL), (NULL), (NULL), (NULL), (NULL), (NULL), (NULL), (NULL), (NULL), (NULL); INSERT INTO test4 (a4) VALUES (0), (0), (0), (0), (0), (0), (0), (0), (0), (0); 114

115 CREATE TRIGGER testref AFTER INSERT ON test1 FOR EACH ROW BEGIN INSERT INTO test2 (a2) VALUES NEW.a1; DELETE FROM test3 WHERE a3 = NEW.a1; UPDATE test4 SET b4 = b4 + 1 WHERE a4 = NEW.a1; END; INSERT INTO test1 VALUES (1), (3), (1), (7), (1), (8), (4), (4); SELECT * FROM test1; a

116 CREATE TRIGGER testref AFTER INSERT ON test1 FOR EACH ROW BEGIN INSERT INTO test2 (a2) VALUES NEW.a1; DELETE FROM test3 WHERE a3 = NEW.a1; UPDATE test4 SET b4 = b4 + 1 WHERE a4 = NEW.a1; END; INSERT INTO test1 VALUES (1), (3), (1), (7), (1), (8), (4), (4); SELECT * FROM test2; a

117 CREATE TRIGGER testref AFTER INSERT ON test1 FOR EACH ROW BEGIN INSERT INTO test2 (a2) VALUES NEW.a1; DELETE FROM test3 WHERE a3 = NEW.a1; UPDATE test4 SET b4 = b4 + 1 WHERE a4 = NEW.a1; END; INSERT INTO test1 VALUES (1), (3), (1), (7), (1), (8), (4), (4); SELECT * FROM test3; a

118 CREATE TRIGGER testref AFTER INSERT ON test1 FOR EACH ROW BEGIN INSERT INTO test2 (a2) VALUES NEW.a1; DELETE FROM test3 WHERE a3 = NEW.a1; UPDATE test4 SET b4 = b4 + 1 WHERE a4 = NEW.a1; END; INSERT INTO test1 VALUES (1), (3), (1), (7), (1), (8), (4), (4); SELECT * FROM test4; a4 b

119 Uložené procedury CREATE PROCEDURE Můžeme definovat dva typy uložených procedur. Externí. Tělo procedury je napsaná v programovacím jazyce. Procedura pak během svého běhu volá externí programy, rutiny. SQL. Tělo procedury je napsané v SQL a je definované pouze pro prostředí SQL serveru. 119

120 MySQL CREATE [DEFINER = { user CURRENT_USER }] PROCEDURE sp_name ([proc_parameter[,...]]) [characteristic...] routine_body CREATE [DEFINER = { user CURRENT_USER }] FUNCTION sp_name ([func_parameter[,...]]) RETURNS type [characteristic...] routine_body proc_parameter: [ IN OUT INOUT ] param_name type func_parameter: param_name type type: Any valid MySQL data type characteristic: LANGUAGE SQL [NOT] DETERMINISTIC { CONTAINS SQL NO SQL READS SQL DATA MODIFIES SQL DATA } SQL SECURITY { DEFINER INVOKER } COMMENT 'string' routine_body: Valid SQL procedure statement 120

121 Parametry Parametry jsou defaultně jako IN. Pokud chceme specifikovat parametr jinak musíme použít klíčová slova OUT nebo INOUT před jménem parametru. 121

122 Return Return umožňuje definovat návratový typ procedury. 122

123 routine_body routine_body (tělo procedury) obsahuje validní SQL. Můžeme použít jak jednoduchý SELECT nebo INSERT, tak i složený příkaz uzavřený do BEGIN a END. 123

124 Příklady PROCEDURE mysql> delimiter // mysql> CREATE PROCEDURE simpleproc (OUT param1 INT) BEGIN SELECT COUNT(*) INTO param1 FROM t; END; // Query OK, 0 rows affected (0.00 sec) mysql> delimiter ; mysql> CALL simpleproc(@a); Query OK, 0 rows affected (0.00 sec) mysql> row in set (0.00 sec) 124

125 Příklady FUNCTION mysql> CREATE FUNCTION hello (s CHAR(20)) RETURNS CHAR(50) RETURN CONCAT('Hello, ',s,'!'); Query OK, 0 rows affected (0.00 sec) mysql> SELECT hello('world'); hello('world') Hello, world! row in set (0.00 sec) 125

126 Change of characteristics of a stored procedure or function. ALTER {PROCEDURE FUNCTION} sp_name [characteristic...] characteristic: { CONTAINS SQL NO SQL READS SQL DATA MODIFIES SQL DATA } SQL SECURITY { DEFINER INVOKER } COMMENT 'string' 126

127 DROP DROP {PROCEDURE FUNCTION} [IF EXISTS] sp_name 127

128 CALL CALL sp_name([parameter[,...]]) CALL spustí uloženou proceduru definovanou pomocí CREATE PROCEDURE. 128

129 DECLARE DECLARE var_name[,...] type [DEFAULT value] Pomocí declare definujeme lokální proměnné. Může definovat výchozí hodnotu proměnné pomocí klauzule DEFAULT. Hodnota může být samozřejmě výraz, tedy ne konstantní hodnota. Pokud neuvedeme DEFAULT, pak je výchozí hodnotu NULL. 129

130 SELECT INTO CREATE PROCEDURE sp1 (x VARCHAR(5)) BEGIN DECLARE xname VARCHAR(5) DEFAULT 'bob'; DECLARE newname VARCHAR(5); DECLARE xid INT; SELECT xname,id INTO newname,xid FROM table1 WHERE xname = xname; SELECT newname; END; 130

131 Konec. 131/53

SQL. Pohledy, ochrana dat,... Pavel Tyl

SQL. Pohledy, ochrana dat,... Pavel Tyl SQL Pohledy, ochrana dat,... Pavel Tyl 25. 4. 2013 ANY, ALL, SOME SOME == ANY (od SQL92 obě varianty) Př.: Najdi zaměstnance, kteří mají plat větší, než všichni zaměstnanci z Prahy ALL, ANY, SOME SOME

Více

Structured Query Language SQL

Structured Query Language SQL Structured Query Language SQL Spouště DML Řízení transakcí Vložené a dynamické SQL SQL DDL Spouště Integritní omezení Bezpečnost Přístupová práva SQL SEQUEL-XRM, IBM v roce 1974 Neprocedurální jazyk říkáme

Více

Databázové systémy. - SQL * definice dat * aktualizace * pohledy. Tomáš Skopal

Databázové systémy. - SQL * definice dat * aktualizace * pohledy. Tomáš Skopal Databázové systémy - SQL * definice dat * aktualizace * pohledy Tomáš Skopal Osnova přednášky definice dat definice (schémat) tabulek a integritních omezení CREATE TABLE změna definice schématu ALTER TABLE

Více

7. Integrita a bezpečnost dat v DBS

7. Integrita a bezpečnost dat v DBS 7. Integrita a bezpečnost dat v DBS 7.1. Implementace integritních omezení... 2 7.1.1. Databázové triggery... 5 7.2. Zajištění bezpečnosti dat... 12 7.2.1. Bezpečnostní mechanismy poskytované SŘBD... 13

Více

7. Integrita a bezpečnost dat v DBS

7. Integrita a bezpečnost dat v DBS 7. Integrita a bezpečnost dat v DBS 7.1. Implementace integritních omezení... 2 7.1.1. Databázové triggery... 5 7.2. Zajištění bezpečnosti dat... 12 7.2.1. Bezpečnostní mechanismy poskytované SŘBD... 13

Více

SQL - trigger, Databázové modelování

SQL - trigger, Databázové modelování 6. přednáška z předmětu Datové struktury a databáze (DSD) Ústav nových technologií a aplikované informatiky Fakulta mechatroniky, informatiky a mezioborových studií Technická univerzita v Liberci jan.lisal@tul.cz

Více

Kurz Databáze. Obsah. Dotazy. Zpracování dat. Doc. Ing. Radim Farana, CSc.

Kurz Databáze. Obsah. Dotazy. Zpracování dat. Doc. Ing. Radim Farana, CSc. 1 Kurz Databáze Zpracování dat Doc. Ing. Radim Farana, CSc. Obsah Druhy dotazů, tvorba dotazu, prostředí QBE (Query by Example). Realizace základních relačních operací selekce, projekce a spojení. Agregace

Více

InnoDB transakce, cizí klíče, neumí fulltext (a nebo už ano?) CSV v textovém souboru ve formátu hodnot oddělených čárkou

InnoDB transakce, cizí klíče, neumí fulltext (a nebo už ano?) CSV v textovém souboru ve formátu hodnot oddělených čárkou MySQL Typy tabulek Storage Engines MyISAM defaultní, neumí transakce, umí fulltext InnoDB transakce, cizí klíče, neumí fulltext (a nebo už ano?) MEMORY (HEAP) v paměti; neumí transakce ARCHIVE velké množství

Více

Informační systémy 2008/2009. Radim Farana. Obsah. Dotazy přes více tabulek

Informační systémy 2008/2009. Radim Farana. Obsah. Dotazy přes více tabulek 5 Vysoká škola báňská Technická univerzita Ostrava Fakulta strojní, Katedra automatizační techniky a řízení 2008/2009 Radim Farana 1 Obsah Jazyk SQL, Spojení tabulek, agregační dotazy, jednoduché a složené

Více

Databázové systémy. Cvičení 6: SQL

Databázové systémy. Cvičení 6: SQL Databázové systémy Cvičení 6: SQL Co je SQL? SQL = Structured Query Language SQL je standardním (ANSI, ISO) textovým počítačovým jazykem SQL umožňuje jednoduchým způsobem přistupovat k datům v databázi

Více

2. blok část B Základní syntaxe příkazů SELECT, INSERT, UPDATE, DELETE

2. blok část B Základní syntaxe příkazů SELECT, INSERT, UPDATE, DELETE 2. blok část B Základní syntaxe příkazů SELECT, INSERT, UPDATE, DELETE Studijní cíl Tento blok je věnován základní syntaxi příkazu SELECT, pojmům projekce a restrikce. Stručně zde budou představeny příkazy

Více

Databáze I. Přednáška 4

Databáze I. Přednáška 4 Databáze I Přednáška 4 Definice dat v SQL Definice tabulek CREATE TABLE jméno_tab (jm_atributu typ [integr. omez.], jm_atributu typ [integr. omez.], ); integritní omezení lze dodefinovat později Definice

Více

PL/SQL. Jazyk SQL je jazykem deklarativním, který neobsahuje procedurální příkazy jako jsou cykly, podmínky, procedury, funkce, atd.

PL/SQL. Jazyk SQL je jazykem deklarativním, který neobsahuje procedurální příkazy jako jsou cykly, podmínky, procedury, funkce, atd. PL/SQL Jazyk SQL je jazykem deklarativním, který neobsahuje procedurální příkazy jako jsou cykly, podmínky, procedury, funkce, atd. Rozšířením jazyka SQL o proceduralitu od společnosti ORACLE je jazyk

Více

Databázové systémy Cvičení 5.2

Databázové systémy Cvičení 5.2 Databázové systémy Cvičení 5.2 SQL jako jazyk pro definici dat Detaily zápisu integritních omezení tabulek Integritní omezení tabulek kromě integritních omezení sloupců lze zadat integritní omezení jako

Více

6. SQL složitější dotazy, QBE

6. SQL složitější dotazy, QBE 6. SQL složitější dotazy, QBE Příklady : Veškeré příklady budou dotazy nad databází KONTAKTY nebo KNIHOVNA nebo FIRMA Databáze KONTAKTY OSOBA (Id_osoba, Příjmení, Jméno, Narození, Město, Ulice, PSČ) EMAIL

Více

Návrh a tvorba WWW stránek 1/14. PHP a databáze

Návrh a tvorba WWW stránek 1/14. PHP a databáze Návrh a tvorba WWW stránek 1/14 PHP a databáze nejčastěji MySQL součástí balíčků PHP navíc podporuje standard ODBC PHP nemá žádné šablony pro práci s databází princip práce s databází je stále stejný opakované

Více

Databázové systémy II. KIV/DB2 LS 2007/2008. Zadání semestrální práce

Databázové systémy II. KIV/DB2 LS 2007/2008. Zadání semestrální práce Databázové systémy 2 Jméno a příjmení: Jan Tichava Osobní číslo: Studijní skupina: čtvrtek, 4 5 Obor: ININ SWIN E-mail: jtichava@students.zcu.cz Databázové systémy II. KIV/DB2 LS 2007/2008 Zadání semestrální

Více

Úvod do databázových systémů

Úvod do databázových systémů Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Úvod do databázových systémů Cvičení 8 Ing. Petr Lukáš petr.lukas@vsb.cz Ostrava, 2014 Opakování Entita Entitní typ

Více

Databáze I. Přednáška 6

Databáze I. Přednáška 6 Databáze I Přednáška 6 SQL aritmetika v dotazech SQL lze přímo uvádět aritmetické výrazy násobení, dělení, sčítání, odčítání příklad z minulé přednášky: zdvojnásobení platu všem zaměstnancům UPDATE ZAMESTNANEC

Více

Jazyk SQL 3 - DML, DDL, TCL, DCL

Jazyk SQL 3 - DML, DDL, TCL, DCL Jazyk SQL 3 - DML, DDL, TCL, DCL Michal Valenta Katedra softwarového inženýrství FIT České vysoké učení technické v Praze c Michal Valenta, 2012 BI-DBS, ZS 2012/13 https://edux.fit.cvut.cz/courses/bi-dbs/

Více

Databáze SQL SELECT. David Hoksza http://siret.cz/hoksza

Databáze SQL SELECT. David Hoksza http://siret.cz/hoksza Databáze SQL SELECT David Hoksza http://siret.cz/hoksza Osnova Úvod do SQL Základní dotazování v SQL Cvičení základní dotazování v SQL Structured Query Language (SQL) SQL napodobuje jednoduché anglické

Více

Informační systémy 2008/2009. Radim Farana. Obsah. Jazyk SQL

Informační systémy 2008/2009. Radim Farana. Obsah. Jazyk SQL 4 Vysoká škola báňská Technická univerzita Ostrava Fakulta strojní, Katedra automatizační techniky a řízení 2008/2009 Radim Farana 1 Obsah Jazyk SQL, datové typy, klauzule SELECT, WHERE, a ORDER BY. Doporučená

Více

- sloupcové integritní omezení

- sloupcové integritní omezení CREATE TABLE - CREATE TABLE = definice tabulek a jejich IO - ALTER TABLE = změna definice schématu - aktualizace - INSERT INTO = vkládání - UPDATE = modifikace - DELETE = mazání CREATE TABLE Základní konstrukce

Více

Kapitola 4: SQL. Základní struktura

Kapitola 4: SQL. Základní struktura - 4.1 - Kapitola 4: SQL Základní struktura Množinové operace Souhrnné funkce Nulové hodnoty Vnořené poddotazy (Nested sub-queries) Odvozené relace Pohledy Modifikace databáze Spojené relace Jazyk definice

Více

SQL. strukturovaný dotazovací jazyk. Structured Query Language (SQL)

SQL. strukturovaný dotazovací jazyk. Structured Query Language (SQL) SQL strukturovaný dotazovací jazyk Structured Query Language (SQL) SQL - historie 1974-75 - IBM - 1.prototyp - SEQUEL od 1979 - do praxe - ORACLE (1979) IBM - SQL/DS (1981), DB/2 (1983) postupně přijímán

Více

Jazyk SQL 1. Michal Valenta. Katedra softwarového inženýrství FIT České vysoké učení technické v Praze c Michal Valenta, 2012 BI-DBS, ZS 2011/12

Jazyk SQL 1. Michal Valenta. Katedra softwarového inženýrství FIT České vysoké učení technické v Praze c Michal Valenta, 2012 BI-DBS, ZS 2011/12 Jazyk SQL 1 Michal Valenta Katedra softwarového inženýrství FIT České vysoké učení technické v Praze c Michal Valenta, 2012 BI-DBS, ZS 2011/12 https://edux.fit.cvut.cz/courses/bi-dbs/ Michal Valenta (FIT

Více

Databáze 2011/2012 SQL DDL (CREATE/ALTER/DROP TABLE), DML (INSERT/UPDATE/DELETE) RNDr.David Hoksza, Ph.D. http://siret.cz/hoksza

Databáze 2011/2012 SQL DDL (CREATE/ALTER/DROP TABLE), DML (INSERT/UPDATE/DELETE) RNDr.David Hoksza, Ph.D. http://siret.cz/hoksza Databáze 2011/2012 SQL DDL (CREATE/ALTER/DROP TABLE), DML (INSERT/UPDATE/DELETE) RNDr.David Hksza, Ph.D. http://siret.cz/hksza Osnva Seznámení s SQL Server Management Studiem (SSMS) Základní architektura

Více

Jazyk SQL slajdy k přednášce NDBI001

Jazyk SQL slajdy k přednášce NDBI001 Jazyk SQL slajdy k přednášce NDBI001 Jaroslav Pokorný MFF UK, Praha pokorny@ksi.mff.cuni.cz Dotazovací jazyky 1 Přehled SQL92 1) jazyk pro definici dat, 2) interaktivní jazyk pro manipulaci dat, 3) jazyk

Více

SQL v14. 4D Developer konference. 4D Developer conference 2015 Prague, CZ Celebrating 30 years

SQL v14. 4D Developer konference. 4D Developer conference 2015 Prague, CZ Celebrating 30 years SQL v14 4D Developer konference Obsah části SQL Porovnání 4D a SQL Nové příkazy SQL Upravené příkazy SQL Optimalizace SQL SQL v14 porovnání Definice dat - struktury Manipulace s daty Definice dat Vytvoření

Více

Kapitola 6: Omezení integrity. Omezení domény

Kapitola 6: Omezení integrity. Omezení domény - 6.1 - Omezení domény Referenční integrita Aserce Spouštěče (Triggers) Funkční závislosti Kapitola 6: Omezení integrity Omezení domény Omezení integrity zabraňují poškození databáze; zajišťují, že autorizované

Více

B0M33BDT Technologie pro velká data. Supercvičení SQL, Python, Linux

B0M33BDT Technologie pro velká data. Supercvičení SQL, Python, Linux B0M33BDT Technologie pro velká data Supercvičení SQL, Python, Linux Sergej Stamenov, Jan Hučín 18. 10. 2017 Osnova cvičení Linux SQL Python 2 SQL pro uživatele aneb co potřebuje znát a umět bigdatový uživatel:

Více

Stored Procedures & Database Triggers, Tiskové sestavy v Oracle Reports

Stored Procedures & Database Triggers, Tiskové sestavy v Oracle Reports , Marek Rychlý Vysoké učení technické v Brně Fakulta informačních technologií Ústav informačních systémů Demo-cvičení pro IDS 9. dubna 2014 Marek Rychlý Stored Procedures & Database Triggers, Demo-cvičení

Více

Dotazy v SQL. Výraz relační algebry R1( )[A1,A2,...,Aj] lze zapsat takto: SELECT A1,A2,...,Aj FROM R1 WHERE. Výraz (R1, R2... Rk)( )[A1,A2,...

Dotazy v SQL. Výraz relační algebry R1( )[A1,A2,...,Aj] lze zapsat takto: SELECT A1,A2,...,Aj FROM R1 WHERE. Výraz (R1, R2... Rk)( )[A1,A2,... Jazyk SQL 1 Přehled SQL 1) jazyk pro definici dat (DDL), 2) jazyk pro manipulaci dat (DML), 3) jazyk pro definice pohledů 4) jazyk pro definice IO 5) jazyk pro přiřazení přístupových práv (DCL) 6) řízení

Více

Databáze I. Přednáška 7

Databáze I. Přednáška 7 Databáze I Přednáška 7 Objektové rozšíření SQL Objektově relační databáze SQL:1999 objektové rozšíření SQL vztahuje se k objektově relačním databázovým systémům ukládají objekty do relační databáze umožňují

Více

Databázové systémy Cvičení 5.3

Databázové systémy Cvičení 5.3 Databázové systémy Cvičení 5.3 SQL jako jazyk pro manipulaci s daty SQL jako jazyk pro manipulaci s daty Aktualizace dat v SQL úprava záznamů v relacích (tabulkách) vložení záznamu INSERT INTO oprava záznamu

Více

Úvod do databázových systémů

Úvod do databázových systémů Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Katedra informatiky Database Research Group Úvod do databázových systémů Cvičení 3 Ing. Petr Lukáš petr.lukas@vsb.cz

Více

Databázové systémy I

Databázové systémy I Databázové systémy I Přednáška č. 8 Ing. Jiří Zechmeister Fakulta elektrotechniky a informatiky jiri.zechmeister@upce.cz Skupinové a souhrnné dotazy opakování Obsah Pohledy syntaxe použití význam Vnořené

Více

Úvod do databází. Modelování v řízení. Ing. Petr Kalčev

Úvod do databází. Modelování v řízení. Ing. Petr Kalčev Úvod do databází Modelování v řízení Ing. Petr Kalčev Co je databáze? Množina záznamů a souborů, které jsou organizovány za určitým účelem. Jaké má mít přínosy? Rychlost Spolehlivost Přesnost Bezpečnost

Více

Jaký je rozdíl v definicicíh VARCHAR2(20 BYTE) a VARCHAR2(20 CHAR):

Jaký je rozdíl v definicicíh VARCHAR2(20 BYTE) a VARCHAR2(20 CHAR): Mezi příkazy pro manipulaci s daty (DML) patří : 1. SELECT 2. ALTER 3. DELETE 4. REVOKE Jaké vlastnosti má identifikující relace: 1. Je relace, která se využívá pouze v případě modelovaní odvozených entit

Více

Obchodní akademie a Jazyková škola s právem státní jazykové zkoušky Jihlava

Obchodní akademie a Jazyková škola s právem státní jazykové zkoušky Jihlava Obchodní akademie a Jazyková škola s právem státní jazykové zkoušky Jihlava Šablona 32 VY_32_INOVACE_038.ICT.34 Tvorba webových stránek SQL stručné minimum OA a JŠ Jihlava, VY_32_INOVACE_038.ICT.34 Číslo

Více

Úvod do databázových systémů

Úvod do databázových systémů Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Úvod do databázových systémů Cvičení 5 Ing. Petr Lukáš petr.lukas@vsb.cz Ostrava, 2014 Opakování K čemu se používají

Více

Úvod do databázových systémů

Úvod do databázových systémů Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Úvod do databázových systémů Cvičení 3 Ing. Petr Lukáš petr.lukas@vsb.cz Ostrava, 2014 Opakování 4 fáze vytváření

Více

Semestrální práce z DAS2 a WWW

Semestrální práce z DAS2 a WWW Univerzita Pardubice Fakulta elektrotechniky a informatiky Semestrální práce z DAS2 a WWW Databázová část Matěj Trakal 8.12.2009 Kapitola 1: Obsah KAPITOLA 1: OBSAH 2 KAPITOLA 2: ZÁKLADNÍ CHARAKTERISTIKA

Více

Jazyk SQL databáze SQLite. připravil ing. petr polách

Jazyk SQL databáze SQLite. připravil ing. petr polách Jazyk SQL databáze SQLite připravil ing. petr polách SQL - úvod Structured Query Language (strukturovaný dotazovací jazyk 70. léta min. století) Standardizovaný dotazovací jazyk používaný pro práci s daty

Více

Databázové systémy I

Databázové systémy I 2015 Databázové systémy I PROJEKT 2 ČÁST MIROSLAV POKORNÝ Stránka 0 z 21 Zadání Implementujte datový model vytvořený v první části projektu do relační databáze a vytvořte pohledy a uloženou proceduru dle

Více

1. Relační databázový model

1. Relační databázový model 1. Relační databázový model Poprvé představen 1969 (Dr. Edgar F. Codd) IBM Založeno na Teorii množin Predikátové logice prvního řádu Umožňuje vysoký stupeň nezávislosti dat základ pro zvládnutí sémantiky

Více

Databázové systémy. Datová integrita + základy relační algebry. 4.přednáška

Databázové systémy. Datová integrita + základy relační algebry. 4.přednáška Databázové systémy Datová integrita + základy relační algebry 4.přednáška Datová integrita Datová integrita = popisuje pravidla, pomocí nichž hotový db. systém zajistí, že skutečná fyzická data v něm uložená

Více

8.2 Používání a tvorba databází

8.2 Používání a tvorba databází 8.2 Používání a tvorba databází Slide 1 8.2.1 Základní pojmy z oblasti relačních databází Slide 2 Databáze ~ Evidence lidí peněz věcí... výběry, výpisy, početní úkony Slide 3 Pojmy tabulka, pole, záznam

Více

PG 9.5 novinky ve vývoji aplikací

PG 9.5 novinky ve vývoji aplikací PG 9.5 novinky ve vývoji aplikací P2D2 2016 Antonín Houska 18. února 2016 Část I GROUPING SETS, ROLLUP, CUBE Agregace Seskupení řádků tabulky (joinu) do podmnožin podle určitého kĺıče. Za každou podmnožinu

Více

Informační systémy ve zdravotnictví. 10. cvičení

Informační systémy ve zdravotnictví. 10. cvičení Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Informační systémy ve zdravotnictví 10. cvičení Ing. Petr Lukáš petr.lukas@nativa.cz Ostrava, 2014 Opakování K čemu

Více

Databáze I. 5. přednáška. Helena Palovská

Databáze I. 5. přednáška. Helena Palovská Databáze I 5. přednáška Helena Palovská palovska@vse.cz SQL jazyk definice dat - - DDL (data definition language) Základní databáze, schemata, tabulky, indexy, constraints, views DATA Databáze/schéma

Více

Fakulta elektrotechniky a informatiky Databázové systémy 2. Leden 2010 souhrn. Červené dobře (nejspíš), modré možná

Fakulta elektrotechniky a informatiky Databázové systémy 2. Leden 2010 souhrn. Červené dobře (nejspíš), modré možná ZKOUŠKOVÉ TESTY Leden 2010 souhrn Červené dobře (nejspíš), modré možná Pomocí kterého databázového objektu je implementován ATRIBUT z konceptuálního modelu? sloupec referenční omezení index tabulka Omezení

Více

Jazyk SQL 2. Michal Valenta. Katedra softwarového inženýrství FIT České vysoké učení technické v Praze c M.Valenta, 2011 BI-DBS, ZS 2011/12

Jazyk SQL 2. Michal Valenta. Katedra softwarového inženýrství FIT České vysoké učení technické v Praze c M.Valenta, 2011 BI-DBS, ZS 2011/12 Jazyk SQL 2 Michal Valenta Katedra softwarového inženýrství FIT České vysoké učení technické v Praze c M.Valenta, 2011 BI-DBS, ZS 2011/12 https://edux.fit.cvut.cz/courses/bi-dbs/ M.Valenta (FIT ČVUT) Jazyk

Více

KIV/ZIS cvičení 5. Tomáš Potužák

KIV/ZIS cvičení 5. Tomáš Potužák KIV/ZIS cvičení 5 Tomáš Potužák Úvod do SQL (1) SQL (Structured Query Language) je standardizovaný strukturovaný dotazovací jazyk pro práci s databází Veškeré operace v databázi se dají provádět pomocí

Více

Co bude výsledkem mého SELECTu? RNDr. David Gešvindr MVP: Data Platform MCSE: Data Platform MCSD: Windows Store MCT

Co bude výsledkem mého SELECTu? RNDr. David Gešvindr MVP: Data Platform MCSE: Data Platform MCSD: Windows Store MCT Co bude výsledkem mého SELECTu? RNDr. David Gešvindr MVP: Data Platform MCSE: Data Platform MCSD: Windows Store MCT david@wug.cz @gesvindr Logické zpracování dotazu Jazyk T-SQL je deklarativní Popisujeme,

Více

Konceptuální modelování a SQL

Konceptuální modelování a SQL Konceptuální modelování a SQL přednáška č.? 1/90 Vytváření IS Analýza Návrh Implementace Testování Předání SW Jednotlivé fáze mezi sebou iterují 2/90 Proč modelovat/analyzovat? Standardizované pracovní

Více

Databáze II. 2. přednáška. Helena Palovská

Databáze II. 2. přednáška. Helena Palovská Databáze II 2. přednáška Helena Palovská palovska@vse.cz SQL a aplikace Program přednášky Řízení transakcí v SQL Integritní omezení v SQL Triggery a uložené procedury Zpracování množin záznamů Řízení

Více

Transformace konceptuálního modelu na relační

Transformace konceptuálního modelu na relační Transformace konceptuálního modelu na relační Michal Valenta Katedra softwarového inženýrství Fakulta informačních technologií České vysoké učení technické v Praze c Michal Valenta, 2016 BI-DBS, LS 2015/16

Více

RELAČNÍ DATABÁZOVÉ SYSTÉMY

RELAČNÍ DATABÁZOVÉ SYSTÉMY RELAČNÍ DATABÁZOVÉ SYSTÉMY VÝPIS KONTROLNÍCH OTÁZEK S ODPOVĚDMI: Základní pojmy databázové technologie: 1. Uveďte základní aspekty pro vymezení jednotlivých přístupů ke zpracování hromadných dat: Pro vymezení

Více

Operátory ROLLUP a CUBE

Operátory ROLLUP a CUBE Operátory ROLLUP a CUBE Dotazovací jazyky, 2009 Marek Polák Martin Chytil Osnova přednášky o Analýza dat o Agregační funkce o GROUP BY a jeho problémy o Speciální hodnotový typ ALL o Operátor CUBE o Operátor

Více

Západočeská univerzita v Plzni Katedra informatiky a výpočetní techniky. 9. června 2007. krovacek@students.zcu.cz

Západočeská univerzita v Plzni Katedra informatiky a výpočetní techniky. 9. června 2007. krovacek@students.zcu.cz Databáze čajových sáčků Martina Málková Západočeská univerzita v Plzni Katedra informatiky a výpočetní techniky Databázové systémy 2 9. června 2007 krovacek@students.zcu.cz 1 1 Datová analýza V původním

Více

Úvod do databázových systémů

Úvod do databázových systémů Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Úvod do databázových systémů Cvičení 4 Ing. Petr Lukáš petr.lukas@vsb.cz Ostrava, 2014 Opakování Klauzule příkazu

Více

Materiál ke cvičením - SQL

Materiál ke cvičením - SQL Materiál ke cvičením - 1. Stručná syntaxe vybraných příkazů jazyka (detailní syntaxe příkazů je uvedena on-line manuálech přístupných z prostředí sítě VŠE) SELECT výběr a zobrazení hodnot z databáze: SELECT

Více

DJ2 rekurze v SQL. slajdy k přednášce NDBI001. Jaroslav Pokorný

DJ2 rekurze v SQL. slajdy k přednášce NDBI001. Jaroslav Pokorný DJ2 rekurze v SQL slajdy k přednášce NDBI001 Jaroslav Pokorný 1 Obsah 1. Úvod 2. Tvorba rekurzívních dotazů 3. Počítaní v rekurzi 4. Rekurzívní vyhledávání 5. Logické hierarchie 6. Zastavení rekurze 7.

Více

Úvod do databázových systémů 3. cvičení

Úvod do databázových systémů 3. cvičení Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Úvod do databázových systémů 3. cvičení Ing. Petr Lukáš petr.lukas@nativa.cz Ostrava, 2012 Klauzule příkazu Klauzule

Více

Databázové systémy. Integritní omezení. Vilém Vychodil. V. Vychodil (KMI/DATA1, Přednáška 9) Integritní omezení Databázové systémy 1 / 33

Databázové systémy. Integritní omezení. Vilém Vychodil. V. Vychodil (KMI/DATA1, Přednáška 9) Integritní omezení Databázové systémy 1 / 33 Databázové systémy Integritní omezení Vilém Vychodil KMI/DATA1, Přednáška 9 Databázové systémy V. Vychodil (KMI/DATA1, Přednáška 9) Integritní omezení Databázové systémy 1 / 33 Přednáška 9: Přehled 1 Relační

Více

XMW4 / IW4 Pokročilé SELECT dotazy. Štefan Pataky

XMW4 / IW4 Pokročilé SELECT dotazy. Štefan Pataky XMW4 / IW4 Pokročilé SELECT dotazy Štefan Pataky TOP, OFFSET-FETCH Konverze datových typů Logické funkce Práce s řetězci Poddotazy a množinové dotazy SQL Windowing Agenda TOP TOP omezení počtu vrácených

Více

Verzování a publikace dat na webu za pomoci PostgreSQL

Verzování a publikace dat na webu za pomoci PostgreSQL Prague PostgreSQL Developers' Day 2013 Verzování a publikace dat na webu za pomoci PostgreSQL Jan Pěček Kdo jsem? Jan Pěček Programátor PostgreSQL Jyxo, s.r.o. (Blog.cz) MAFRA, a.s. - Internet Trading

Více

Základní přehled SQL příkazů

Základní přehled SQL příkazů Základní přehled SQL příkazů SELECT Základní použití Příkaz SELECT slouží k získání dat z tabulky nebo pohledu v požadované podobě. Získání všech řádků a sloupců z tabulky SELECT * FROM Person.Contact

Více

6. blok část B Vnořené dotazy

6. blok část B Vnořené dotazy 6. blok část B Vnořené dotazy Studijní cíl Tento blok je věnován práci s vnořenými dotazy. Popisuje rozdíl mezi korelovanými a nekorelovanými vnořenými dotazy a zobrazuje jejich použití. Doba nutná k nastudování

Více

SQL. relační databázový systém. v 5.0.45. 2007 úvodní kurz jazyka SQL -----------------------------------------------------------

SQL. relační databázový systém. v 5.0.45. 2007 úvodní kurz jazyka SQL ----------------------------------------------------------- 2007 úvodní kurz jazyka SQL ----------------------------------------------------------- SQL relační databázový systém v 5.0.45 (c) 2007 Ing. Jan Steringa Úvodní kurz jazyka SQL. Tento studijní materiál

Více

DUM 12 téma: Příkazy pro tvorbu databáze

DUM 12 téma: Příkazy pro tvorbu databáze DUM 12 téma: Příkazy pro tvorbu databáze ze sady: 3 tematický okruh sady: III. Databáze ze šablony: 7 Kancelářský software určeno pro: 4. ročník vzdělávací obor: 18-20-M/01 Informační technologie vzdělávací

Více

Inovace a zkvalitnění výuky prostřednictvím ICT. Základní seznámení s MySQL Ing. Kotásek Jaroslav

Inovace a zkvalitnění výuky prostřednictvím ICT. Základní seznámení s MySQL Ing. Kotásek Jaroslav Střední průmyslová škola a Vyšší odborná škola technická Brno, Sokolská 1 Šablona: Název: Téma: Autor: Číslo: Anotace: Inovace a zkvalitnění výuky prostřednictvím ICT Databáze Základní seznámení s MySQL

Více

Databázové systémy Cvičení 5

Databázové systémy Cvičení 5 Databázové systémy Cvičení 5 Dotazy v jazyce SQL SQL jako jazyk pro manipulaci s daty Aktualizace dat v SQL úprava záznamů v relacích (tabulkách) vložení záznamu INSERT INTO oprava záznamu UPDATE vymazání

Více

Kód v databázi. RNDr. Ondřej Zýka

Kód v databázi. RNDr. Ondřej Zýka Kód v databázi RNDr. Ondřej Zýka 1 Obsah Jazyk Skripty Funkce Procedury Triggery Správa chyb Java, CLR, apod.. Dobré a špatné praktiky 2 PL/SQL Jazyk Oracle Inspirovaný jazykem ADA Objektový Samostatné

Více

KIV/ZIS cvičení 6. Tomáš Potužák

KIV/ZIS cvičení 6. Tomáš Potužák KIV/ZIS cvičení 6 Tomáš Potužák Pokračování SQL Klauzule GROUP BY a dotazy nad více tabulkami Slučování záznamů do skupin (1) Chceme zjistit informace obsažené ve více záznamech najednou Klauzule GROUP

Více

MySQL. mysql> CREATE DATABASE nova CHARACTER SET latin2 COLLATE latin2_czech_cs; Query OK, 1 row affected (0.02 sec)

MySQL. mysql> CREATE DATABASE nova CHARACTER SET latin2 COLLATE latin2_czech_cs; Query OK, 1 row affected (0.02 sec) MySQL přes MySQL Command Line Client Zobrazení existujících databází mysql> SHOW DATABASES; Database test Vytvoření databáze mysql> CREATE DATABASE krouzek; Query OK, 1 row affected (0.00 sec) mysql> SHOW

Více

Vzorové příklady SQL. Tabulka: Kniha CREATE TABLE kniha (id INTEGER, název VARCHAR(50), PRIMARY KEY (id))

Vzorové příklady SQL. Tabulka: Kniha CREATE TABLE kniha (id INTEGER, název VARCHAR(50), PRIMARY KEY (id)) Vzorové příklady SQL Tabulka: Kniha CREATE TABLE kniha název VARCHAR(50, PRIMARY KEY (id Tabulka: Autoři CREATE TABLE autoři jméno VARCHAR(10, příjmení VARCHAR(20, titul VARCHAR(7, prostřední VARCHAR(10,

Více

Databáze. Velmi stručný a zjednodušený úvod do problematiky databází pro programátory v Pythonu. Bedřich Košata

Databáze. Velmi stručný a zjednodušený úvod do problematiky databází pro programátory v Pythonu. Bedřich Košata Databáze Velmi stručný a zjednodušený úvod do problematiky databází pro programátory v Pythonu Bedřich Košata K čemu jsou databáze Ukládání dat ve strukturované podobě Možnost ukládat velké množství dat

Více

Databáze I. 1. přednáška. Helena Palovská

Databáze I. 1. přednáška. Helena Palovská Databáze I 1. přednáška Helena Palovská palovska@vse.cz Co je databáze Mnoho dat Organizovaných používá se model uspořádání Řízený přístup k datům přijímá požadavky v jazyce modelu umožňuje sdílení dat

Více

Gymnázium a Střední odborná škola, Rokycany, Mládežníků 1115

Gymnázium a Střední odborná škola, Rokycany, Mládežníků 1115 Gymnázium a Střední odborná škola, Rokycany, Mládežníků 1115 Číslo projektu: Číslo šablony: Název materiálu: Ročník: Identifikace materiálu: Jméno autora: Předmět: Tématický celek: Anotace: CZ.1.07/1.5.00/34.0410

Více

Text úlohy. Systémový katalog (DICTIONARY):

Text úlohy. Systémový katalog (DICTIONARY): Úloha 1 Částečně správně Bodů 050 / 100 Systémový katalog (DICTIONARY): a Se skládá z tablek a pohledů uložených v tabulkovém SYSTEM b Všechny tabulky vlastní uživatel SYS c Se skládá z tablek a pohledů

Více

Marian Kamenický. Syntea software group a.s. marian.kamenicky. kamenicky@syntea.cz. MFFUK Praha 2012/13

Marian Kamenický. Syntea software group a.s. marian.kamenicky. kamenicky@syntea.cz. MFFUK Praha 2012/13 Datové a procesní modely Relační databáze Přednáška 5 Marian Kamenický Syntea software group a.s. marian.kamenicky kamenicky@syntea.cz MFFUK Praha 2012/13 1 Poddotazy OsoReg Jm Poh St Pepa m CZ Franz m

Více

Administrace Oracle. Práva a role, audit

Administrace Oracle. Práva a role, audit Administrace Oracle Práva a role, audit Filip Řepka 2010 Práva (privileges) Objekty (tabulky, pohledy, procedury,...) jsou v databázi logicky rozděleny do schémat. Každý uživatel má přiděleno svoje schéma

Více

Databáze II. 1. přednáška. Helena Palovská palovska@vse.cz

Databáze II. 1. přednáška. Helena Palovská palovska@vse.cz Databáze II 1. přednáška Helena Palovská palovska@vse.cz Program přednášky Úvod Třívrstvá architektura a O-R mapování Zabezpečení dat Role a přístupová práva Úvod Co je databáze Mnoho dat Organizovaných

Více

Informační systémy ve zdravotnictví. 6. cvičení

Informační systémy ve zdravotnictví. 6. cvičení Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Informační systémy ve zdravotnictví 6. cvičení Ing. Petr Lukáš petr.lukas@nativa.cz Ostrava, 2014 Opakování Relace

Více

Použití databází na Webu

Použití databází na Webu 4IZ228 tvorba webových stránek a aplikací Jirka Kosek Poslední modifikace: $Date: 2010/11/18 11:33:52 $ Obsah Co nás čeká... 3 Architektura webových databázových aplikací... 4 K čemu se používají databázové

Více

Univerzita Palackého v Olomouci Radek Janoštík (Univerzita Palackého v Olomouci) Základy programování 4 - C# 10.4.

Univerzita Palackého v Olomouci Radek Janoštík (Univerzita Palackého v Olomouci) Základy programování 4 - C# 10.4. Základy programování 4 - C# - 9. cvičení Radek Janoštík Univerzita Palackého v Olomouci 10.4.2017 Radek Janoštík (Univerzita Palackého v Olomouci) Základy programování 4 - C# 10.4.2017 1 / 13 Reakce na

Více

Materializované pohledy

Materializované pohledy Materializované pohledy Pavel Baroš, 2010 Obsah Materializované pohledy Co přináší? Řešení ostatních DBS syntaxe a semantika pro: Oracle, MS SQL, DB2 ostatní Možné řešení pro PostgreSQL PostgreSQL 2 Materializované

Více

Uložené procedury Úvod ulehčit správu zabezpečení rychleji

Uložené procedury Úvod ulehčit správu zabezpečení rychleji Uložené procedury Úvod Uložená procedura (rutina) je sada příkazů SQL, které jsou uložené na databázovém serveru a vykonává se tak, že je zavolána prostřednictvím dotazu názvem, který jim byl přiřazen

Více

Virtual private database. Antonín Steinhauser

Virtual private database. Antonín Steinhauser Virtual private database Antonín Steinhauser Základní princip VPD Rozšíření bezpečnostní politiky Oracle o omezení na úrovni jednotlivých řádků a sloupců Pro uživatele, kterého se bezpečnostní politika

Více

Primární klíč (Primary Key - PK) Je právě jedna množina atributů patřící jednomu z kandidátů primárního klíče.

Primární klíč (Primary Key - PK) Je právě jedna množina atributů patřící jednomu z kandidátů primárního klíče. Primární a cizí klíč Kandidát primárního klíče (KPK) Je taková množina atributů, která splňuje podmínky: Unikátnosti Minimálnosti (neredukovatelnosti) Primární klíč (Primary Key - PK) Je právě jedna množina

Více

Obsah. Kapitola 1. Kapitola 2. Kapitola 3. Kapitola 4. Úvod 11. Stručný úvod do relačních databází 13. Platforma 10g 23

Obsah. Kapitola 1. Kapitola 2. Kapitola 3. Kapitola 4. Úvod 11. Stručný úvod do relačních databází 13. Platforma 10g 23 Stručný obsah 1. Stručný úvod do relačních databází 13 2. Platforma 10g 23 3. Instalace, první přihlášení, start a zastavení databázového serveru 33 4. Nástroje pro administraci a práci s daty 69 5. Úvod

Více

Integritní omezení (IO)

Integritní omezení (IO) Integritní omezení (IO) IO jsou tvrzení vymezující korektnost DB, stupeň souladu datového obrazu s předlohou (jaká data v databází mohou být a jaká již ne). definují se na konceptuální i databázové úrovni

Více

Optimalizace dotazů a databázové transakce v Oracle

Optimalizace dotazů a databázové transakce v Oracle Optimalizace dotazů a databázové transakce v Oracle Marek Rychlý Vysoké učení technické v Brně Fakulta informačních technologií Ústav informačních systémů Demo-cvičení pro IDS 22. dubna 2015 Marek Rychlý

Více

Sada 1 - PHP. 14. Úvod do jazyka SQL

Sada 1 - PHP. 14. Úvod do jazyka SQL S třední škola stavební Jihlava Sada 1 - PHP 14. Úvod do jazyka SQL Digitální učební materiál projektu: SŠS Jihlava šablony registrační číslo projektu:cz.1.09/1.5.00/34.0284 Šablona: III/2 - inovace a

Více

Inovace a zkvalitnění výuky prostřednictvím ICT Databázové systémy MySQL základní pojmy, motivace Ing. Kotásek Jaroslav

Inovace a zkvalitnění výuky prostřednictvím ICT Databázové systémy MySQL základní pojmy, motivace Ing. Kotásek Jaroslav Střední průmyslová škola a Vyšší odborná škola technická Brno, Sokolská 1 Šablona: Název: Téma: Autor: Číslo: Anotace: Inovace a zkvalitnění výuky prostřednictvím ICT Databázové systémy MySQL základní

Více

Databázové systémy a SQL

Databázové systémy a SQL Databázové systémy a SQL Daniel Klimeš Autor, Název akce 1 About me Daniel Klimeš Vzdělání: Obecná biologie PGS: onkologie Specializace: klinické databáze Databáze ORACLE klimes@iba.muni.cz Kotlářská 2,

Více

O Apache Derby detailněji. Hynek Mlnařík

O Apache Derby detailněji. Hynek Mlnařík O Apache Derby detailněji Hynek Mlnařík Agenda Historie Vlastnosti Architektura Budoucnost Historie 1997 Cloudscape Inc. - JBMS 1999 Informix Software, Inc. odkoupila Cloudscape, Inc. 2001 IBM odkoupila

Více

Deklarativní IO shrnutí minulé přednášky

Deklarativní IO shrnutí minulé přednášky Deklarativní IO shrnutí minulé přednášky Existují následující typy omezení: NOT NULL UNIQUE Key PRIMARY KEY FOREIGN KEY CHECK Pro zobrazení všech definic a názvů IO se použije dotaz na pohledy data dictionary

Více