Dotazovací jazyk SQL a PL/SQL. 8. Přednáška

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

Download "Dotazovací jazyk SQL a PL/SQL. 8. Přednáška"

Transkript

1 Dotazovací jazyk SQL a PL/SQL 8. Přednáška

2 Úvod do PL/SQL Proprietární rozšíření firmy Oracle Usazuje se i v ne-oracle RDBMS Procedurální rozšíření SQL Přidává základní programátorskou logiku a kontrolu SQL Procedurální jazyk

3 Proč PL/SQL SQL je deklarativní jazyk Na některé specifické operace potřebujeme programovat ve vhodném paradigmatu (podporujícím struktury) Přináší možnost programovat v SQL klasickou cestou (ala Pascal či C) Založen na limitech SQL pro jejich odstranění

4 Využití PL/SQL Programový kód lze v Oracle vkládat na celou řadu míst: přímé volání PL/SQL v rámci SQL uložené procedury funkce programové balíky spouště (triggery) metody objektových tříd

5 Lexikální jednotky Identifikátory Klíčová slova Oddělovače Literály Komentáře

6 Klíčová slova Další klíčová slova naleznete v dokumentaci. ( rved_words.htm)

7 Použití klíčových slov Co se stane, když použijete klíčové slovo jako identifikátor?

8 Identifikátory Pojmenování PL/SQL objektů Pravidla pro tvorbu pojmenování objektů Maximální počet znaků je 30 Musí začínat písmenem Mohou obsahovat znaky: písmena, číslice, $, _ a # Nesmí obsahovat mezery Všechny identifikátory jsou Case Sensitive

9 Identifikátory

10 PL/SQL Best Practices

11 PL/SQL Best Practices Konvence pro pojmenování identifikátorů Proměnné budou začínat v_název Konstanty začínají c_název Parametry (předávané funkcím a procedurám) p_název Kurzory mívají příponu název_cur Odsazuje kód dle významu Vřele doporučuji dodržovat výše zmíněná doporučení

12 Objekty PL/SQL Balíky Funkce Konstanty Kurzory PL/SQL tabulky Procedury Proměnné Výjimky Záznamy

13 Základní struktura Každý programový kód v PL/SQL má následující strukturu: [ DECLARE -- declarations ] BEGIN -- statements [ EXCEPTION -- handlers ] END;

14 Ahoj Světe! BEGIN DBMS_OUTPUT.PUT_LINE('Ahoj Světe!'); END;

15 Komentáře v PL/SQL Každý programovací jazyk podporuje komentáře, které vám umožní psát přehledně a strukturovaně Jednořádkový komentář -- komentář Víceřádkový komentář /* komentář */

16 Proměnné Musí se před prvním použitím deklarovat Podporované datové typy: libovolný SQL typ mimo LOB identifikátoru (BLOB, CLOB, BFILE) speciální PL/SQL typy (BINARY_INTEGER, PLS_INTEGER, BOOLEAN) nebo jejich podtypy složené datové typy (RECORD, VARRAY, TABLE) Podrobnosti viz 111/b28370/datatypes.htm

17 Deklarace proměnné Příklad na deklaraci proměnné: DECLARE cislo NUMBER(4); i PLS_INTEGER; ks POSITIVE NOT NULL := 3; uspech BOOLEAN DEFAULT TRUE; text VARCHAR2(3000); BEGIN -- programový blok END;

18 Základní skalární datové typy Znakové: CHAR, VARCHAR2, LONG; Číselné: NUMBER, PLS_INTEGER, BINARY_INTEGER, BINARY_FLOAT; Datové: DATE, TIMESTAMP, TIMESTAMP WITH TIMEZONE; Logické: BOOLEAN; %TYPE slouží pro přiřazení stejného typu jako má např. sloupec tabulky (viz později)

19 Přiřazení hodnoty do proměnné Existují tři možnosti přirazení hodnoty do deklarované proměnné: příkazem pro přiřazení hodnoty ( := ) výběrem hodnoty z dotazu, jehož výsledkem je jeden řádek (konkrétní hodnota): SELECT AVG(sal) INTO my_sal FROM emp; výstupního hodnota procedury (tzv. OUT nebo IN OUT parametr procedury): adjust_salary(7788, my_sal);

20 Užití proměnné Proměnné je možné dále užívat jak v PL/SQL, tak v SQL kódu (příkazy SQL mohou být volně užívány v PL/SQL bloku) Typické užití proměnné: výpočet výrazu parametry v SQL (přímým zadáním do SQL) předání parametru to procedury či funkce podmínky a cykly výraz, iterátor Proměnné jsou deklarovány (platné) jen pro následující blok (viditelnost, tzv. scope) Databázové položky mají před proměnnými přednost (PL/SQL vychází z SQL)

21 Konstanty Představují read-only proměnné Musí být inicializovány v okamžiku deklarace ( DEFAULT, := ) stejně jako NOT NULL proměnné Klíčové slovo CONSTANT Př. DECLARE pi CONSTANT REAL DEFAULT ;

22 PL/SQL implicitní konverze

23 PL/SQL explicitní konverze Pro explicitní konverzi slouží k tomu určené funkce.

24 PL/SQL Best Practices Pro deklarace používejte Smysluplná jména Jeden identifikátor na řádku Využívejte NOT NULL omezení pro proměnné, které musí obsahovat hodnotu Nepoužívejte pro název proměnné název sloupce Používejte %TYPE deklarace pro proměnné, které dědí vlastnosti dříve použitých (deklarovaných) proměnných

25 Zanořování bloků

26 Pojmenování bloků

27 SQL funkce v PL/SQL

28 SQL funkce v PL/SQL

29 Operátory

30 Řídící struktury Mezi řídící struktury patří: rozhodování (if), způsob vyhodnocování vícehodnotové rozhodování (case) iterace (nekonečná loop) cyklus s podmínkou v průběhu či na konci (exit-when-loop) cyklus s podmínkou na začátku (while-loop) sekvenční cyklus (for-loop) řízení cyklů řízení posloupnosti příkazů a skoky příkaz NULL

31 Základní rozhodování Větvení (rozhodování) v programovém kódu realizuje podmíněný příkaz IF IF podmínka THEN -- posloupnost příkazů [ ELSIF podmínka THEN -- posloupnost příkazů ] [ ELSE -- posloupnost příkazů ] END IF;

32 Způsob vyhodnocování Oracle PL/SQL používá pro vyhodnocení výrazů na místě podmínek zkrácenou Booleanovu logiku tzn. vyhodnocuje zleva doprava a při prvním pozitivní úspěchu OR podmínky či prvním negativním úspěchu AND podmínky končí s vyhodnocováním příslušné části výrazu

33 Vícehodnotové rozhodování Nahrazení posloupnosti IF ELSIF nad stejnou posuzovanou proměnnou (selektor) Selektor musí být jednoduchá (jednohodnotová) proměnná První úspěšná WHEN ukončuje CASE CASE proměnná WHEN hodnota 1 THEN příkazy 1 ; WHEN hodnota 2 THEN příkazy 2 ; WHEN hodnota 3 THEN příkazy 3 ; [ ELSE příkazy ELSE ; ] END CASE;

34 Další možnosti CASE Není-li uvedena větev ELSE, je použita implicitní větev: ELSE RAISE case_not_found; Příkaz CASE lze identicky použít také v SQL pro určení hodnoty nebo ve výrazu PL/SQL V libovolném místě, kde je potřeba vybrat hodnotu se místo posloupnosti příkazů v daném případě uvede jedna hodnota Výraz CASE končí END místo END CASE

35 CASE s plnou podmínkou Tzv. searched CASE (podporována je tatáž funkce pro výraz CASE) umožňuje místo selektoru a množiny případů (hodnot) definovat případy podmínkou CASE WHEN podmínka 1 THEN příkazy 1 ; WHEN podmínka 2 THEN příkazy 2 ; [ ELSE příkazy ELSE ; ] END CASE;

36 Nekonečná iterace Základní tvar cyklu představuje nekonečnou iteraci (nekonečný cyklus) LOOP -- posloupnost příkazů END LOOP; Přerušení běhu iterace příkaz EXIT Obvyklá kombinace s rozhodováním (IF)

37 Cyklus s podmínkou na konci Kombinace IF a EXIT umožňuje přerušit cyklus kdykoliv v jeho průběhu Speciální případ je rozhodování s EXIT jako poslední příkaz cyklu tzv. cyklus s podmínkou na konci (typický repeat) Místo zdlouhavého zápisu IF EXIT lze užívat zápisu EXIT WHEN LOOP EXIT WHEN podmínka; END LOOP;

38 Pojmenovávání cyklů Jednotlivé cykly (LOOP) či vícehodnotové rozhodování (CASE) lze pojmenovat pomocí návěští, ukončit pak lze lib. cyklus <<outer>> LOOP LOOP EXIT outer WHEN podmínka; END LOOP; END LOOP outer;

39 Cyklus s podmínkou na začátku Jedná se o standardní while cyklus Iteraci je předřazena rozhodovací podmínka prováděná vždy před provedením těla iterace Možnost řízení pomocí EXIT WHILE podmínka LOOP -- posloupnost příkazů END LOOP;

40 Sekvenční cyklus Tzv. cyklus s pevným počtem opakování Iterátor (čítač) je implicitně deklarován jako typ INTEGER a je viditelný (scope) jen uvnitř cyklu Klasický for cyklus s hranicemi <l, h> FOR counter IN [ REVERSE ] l..h LOOP -- posloupnost příkazů END LOOP;

41 Posloupnost příkazů Není možné ukončit EXIT (slouží jen pro cykly), je nutné užít příkaz RETURN Pro skok na návěští lze užít příkazu GOTO Návěští definujeme pomocí <<label>> BEGIN GOTO insert_row; <<insert_row>> INSERT INTO emp VALUES END;

42 Omezení skoků Nelze provést skok do rozhodování, těla všech druhů iterací či podbloku Také nelze skákat mezi různými bloky stejné úrovně (např. THEN a ELSE blok) Rovněž nelze skákat z podprogramu do volajícího programu Naopak lze provést skok z uvedeného do vyšších programových bloků Skákat lze dopředu i zpět Také lze skákat z ošetření výjimek zpět

43 Zvláštní příkaz NULL Příkaz NULL představuje tělo podprogramu nevykonávajícího žádnou činnost Je užitečný tam, kde syntaxe nutí zadat příkaz či příkazy, ale my potřebujeme ponechat tuto část prázdnou Také je vhodný pro navrhování programu metodou shora-dolů NULL;

44 Kurzory Kurzor je pracovní oblast obsahující data (výsledná množina, tzv. result set), které lze dále využívat prostřednictvím operací nad kurzory Existují implicitní a explicitní kurzory Implicitní jsou jednořádkové SQL (INTO) Explicitní můžeme deklarovat v části DECLARE pomocí klíčového slova CURSOR Práce s kurzory se podobá souborům

45 Deklarace kurzoru Pomocí klíčového slova CURSOR vytvoříme ukazatel do pracovní oblasti s daty, která získáme pomocí SQL příkazu DECLARE CURSOR prvni_cur IS SELECT id_zamestnanci, prjmeni FROM zamestnanci WHERE plat > ORDER BY plat DESC;

46 Postup zpracování kurzoru Funguje stejně jako přístup k souborům Existují operace OPEN cursor FETCH cursor INTO record CLOSE cursor Postup práce spočívá v otevření, postupném vyčtení jednotlivých záznamů (čtení s posunem) a uzavření kurzoru Pro zjištění stavu kurzoru existují atributy

47 Atributy (modifikátory) kurzoru Existují následující atributy za jménem kurzoru: cursor%found obsahuje záznamy? cursor%notfound neobsahuje záznamy? cursor%isopen je otevřený? cursor%rowcount dosud zpracováno řádků Existují také atributy pro definice typů: tab%rowtype záznam typu řadku tabulky tab.column%type typ sloupce

48 DECLARE v_id zamestnanci.id_zamestnanci%type; v_prijmeni zamestnanci.prijmeni%type; CURSOR zam_cur IS SELECT BEGIN OPEN zam_cur; LOOP FETCH zam_cur INTO v_id, v_prijmeni; EXIT WHEN zam_cur%notfound; END LOOP; CLOSE zam_cur; END; Příklad vyčtení kurzoru

49 Najděte rozdíl DECLARE v_emp_id...; v_first_name...;... v_department_id...: CURSOR emp_cursor IS SELECT * FROM employees WHERE department_id =30; BEGIN OPEN emp_cursor; LOOP FETCH emp_cursor INTO v_emp_id, v_first_name,... v_department_id;... DECLARE CURSOR emp_cursor IS SELECT * FROM employees WHERE department_id = 30; v_emp_record emp_cursor%rowtype; BEGIN OPEN emp_cursor; LOOP FETCH emp_cursor INTO v_emp_record;...

50 Iterace kurzorem pomocí FOR Cyklus FOR zajišťuje průchod celým deklarovaným kurzorem Iterátor vzniká implicitně po dobu cyklu Otevření a zavření kurzoru zajistí samotný cyklus FOR r IN c1 LOOP dbms_output.put_line(r.name); END LOOP;

51 Parametrické kurzory Některé kurzory mohou být závislé na parametru (tzv. parametrické kurzory) Deklarují se s uvedením parametrů a jejich typů tyto parametry lze potom užít v SQL příkazu Při otevírání kurzoru (nebo v části IN cyklu FOR) potom specifikujeme konkrétní hodnoty pro parametry Parametry lze užít i v řetězcích typu LIKE

52 Příklad parametrického kurzoru DECLARE CURSOR c1(min IN NUMBER) IS SELECT emp_id, name FROM emp WHERE age > min ORDER BY age DESC; BEGIN OPEN c1(18);

53 Omezení kurzorů Kurzory nemohou zajistit variantní tvorbu SQL dotazu (např. přidání či vypuštění podmínky selekce či stanovení řazení) Jsou určeny pro statické SQL dotazy Existuje PL/SQL podpora také pro dynamické SQL dotazy, které jsou tvořeny za běhu Některé dynamické SQL dotazy (tzv. nativní) pracují podobně jako kurzory Musí být ale jednotného typu projekce

54 Definice kurzoru jako tzv. odkazu Zadefinování dotazu klauzulí FOR DECLARE TYPE typ_c1 IS REF CURSOR; c1 typ_c1; record emp%rowtype; BEGIN OPEN c1 FOR SELECT id FROM emp ; Užití nativního dynsql

55 Výjimky v PL/SQL Co když ale vložíme špatně název země?

56 Výjimky v PL/SQL - pokračování

57 Typy chyby Systémové chyby (např. zaplněný hard disk) Datové chyby (např. pokus o duplicitní vložení primárního klíče) Uživatelské chyby (např. snaha získat neexistující data) Mnoho dalších

58 Proč je potřeba tyto chyby ošetřovat? Ochránit uživatele (častý výskyt chybových hlášení může uživatele frustrovat, tak že uživatel přestane používat takovou aplikaci) Ochránit databázi (data by mohla být ztracena nebo přepsána) Zásadní chyby berou mnoho ze systémových zdrojů (neošetření chyb může způsobit časté dotazy uživatelů, a tak může být přetížena asistenční služba) Zpřehlednění kódu. Ošetření výjimek může být provedeno ve stejném bloku.

59 Chybová hlášení Oracle Oracle generuje chybová hlášení v rozsahu 0 až Uživatel si může dále dodefinovat chybová hlášení v rozsahu až Ke každé chybě lze stanovit text hlášení s délkou maximálně 2000 znaků Chyba 0 znamená úspěch Detekci chyb lze řešit v časti EXCEPTION

60 Příklady předdefinovaných výjimek NO_DATA_FOUND TOO_MANY_ROWS INVALID_CURSOR ZERO_DIVIDE DUP_VAL_ON_INDEX VALUE_ERROR Více na 2/e10472/errors.htm#BABHDGGG

61 Řízení předdefinovaných výjimek Specifikováním akronymu výjimky (obecné pojmenování) v časti EXCEPTION zabráníme implicitní akci (konec PL/SQL kódu a oznámení chyby) a můžeme provést vlastní akci EXCEPTION ZERO_DIVIDE THEN -- ošetření příslušné výjimky END;

62 Vícenásobná detekce výjimek Je nutné v časti EXCEPTION použít výběr pomocí klauzule WHEN EXCEPTION WHEN ZERO_DIVIDE THEN -- ošetření WHEN OTHERS THEN -- ošetření END;

63 Úkol 1 Na základě zvoleného jména a příjmení vypište plat zaměstnance. V případě, že takový zaměstnanec neexistuje, vypište větu: Takovýto zaměstnanec neexistuje. V případě, že je více zaměstnanců s tímto jménem a příjmením vypište větu: Nelze jednoznačně určit, kterého zaměstnance máte na mysli.

64 Řízení nepředdefinovaných výjimek Je to podobné jako u předdefinovaných, pouze nemají předdefinované jméno. Jedná se o standardní výjimky s ORA-číslo chyby. Je možné si vytvořit vlastní pojmenování v části DECLARE spojením chybového čísla a jména pomocí funkce PRAGMA EXCEPTION_INIT

65 Řízení nepředdefinovaných výjimek pokračování Způsob, jak vyřešit tento problém je spojit chybu ORA s vlastím jménem

66 Řízení nepředdefinovaných výjimek pokračování 1. Deklarovat jméno výjimky v části deklarací. 2. Propojit deklarovanou výjimku se standardním chybovým číslem pomocí funkce PRAGMA EXCEPTION_INIT. 3. Použít deklarovanou výjimku v části ošetření výjimek.

67 Řízení nepředdefinovaných výjimek pokračování

68 Úkol 2 V rámci nepojmenovaného bloku se pokuste vložit do tabulky producenti nový řádek (úmyslně vynechte některý z povinných sloupců). Ošetřete, aby při vzniklé chybě bylo vypsáno: Nového producenta se nepodařilo vložit.

69 Uživatelem definované výjimky Mějme následující blok příkazů: Co se stane, kdy vyhledáváte neexistující oddělení? Tento kód nevyprodukuje žádnou chybu. Proto je potřeba definovat a vyvolat vlastí chybu

70 Uživatelem definované výjimky pokračování 1. Deklarace jména uživatelem definované výjimky v části deklarací: e_invalid_department EXCEPTION; 2. Použití RAISE k vyvolání výjimky v části příkazů: IF SQL%NOTFOUND THEN RAISE e_invalid_department; 3. V části zpracování výjimek odchytnout a zpracovat danou chybu: EXCEPTION WHEN e_invalid_department THEN DBMS_ OUTPUT. PUT_ LINE('CHYBA... ');

71 Uživatelem definované výjimky pokračování

72 Úkol 3 Prosřednictvím nepojmenovaného bloku změňte minimální plat na vámi načtenou hodnotu všem pracovním pozicím, které mají minimální plat nižší než je tato částka, avšak minimální plat nesmí být vyšší než maximální. V případě, že nebude provedena žádná změna vyvolejte vlastní výjimku a tuto výjimku zpracujte v části EXCEPTION.

73 RAISE_APPLICATION_ERROR Existuje procedura RAISE_APPLICATION_ERROR s parametry kód chyby a text chybového hlášení RAISE_APPLICATION_ERROR (error_number, message [, {TRUE FALSE}]); error_number je uživatelem specifikované číslo pro výjimku mezi a message je uživatelem specifikovaná zpráva výjimky maximální délky 2048 B. TRUE FALSE je volitelné. Pokud se použije TRUE, chyba se vloží do zásobníku chyb, při FALSE (defaultní) chyba nahradí všechny předchozí chyby.

74 Příklad užití

75 Úkol 4 Přepracujte předchozí úkol tak, aby se místo vysání informace o neprovedení změny vyskytla chybová hláška

76 Příklad užití

77 Úkol 5 Spojte předchozí dva příklady. To znamená, že v případě, že nebude provedena změna, vyhodíte ERROR V části deklarací tento error propojte s Vámi deklarovanou výjimkou a tuto výjimku zpracujte.

78 Funkce SQLCODE a SQLERRM SQLCODE má smysl použít pouze v části EXCEPTION. Návratovou hodnotou je chybové číslo vyvolané chyby. SQLERRM(cislo) vrací chybové hlášení vztahující se k chybě s číslem cislo. Příklad použití: DBMS_OUTPUT.PUT_LINE (SQLCODE ' ' SQLERRM(SQLCODE));

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

Jazyk PL/SQL Úvod, blok

Jazyk PL/SQL Úvod, blok Jazyk PL/SQL Úvod, blok 1 Bc. Tomáš Romanovský Procedural Language for Structured Query Language Součást systému Oracle, rozšíření SQL o procedurální rysy Prostředky pro vytváření a spouštění programových

Více

Programovací jazyk Pascal

Programovací jazyk Pascal Programovací jazyk Pascal Syntaktická pravidla (syntaxe jazyka) přesná pravidla pro zápis příkazů Sémantická pravidla (sémantika jazyka) pravidla, která každému příkazu přiřadí přesný význam Všechny konstrukce

Více

řízení transakcí 2-3 hodiny

řízení transakcí 2-3 hodiny 7. blok - část A Jazyk PL/SQL - zpracování chyb, řízení transakcí Studijní cíl Tento blok je věnován ošetření chyb a řízení transakcí v kódu PL/SQL. Doba nutná k nastudování 2-3 hodiny Průvodce studiem

Více

6 Příkazy řízení toku

6 Příkazy řízení toku 6 Příkazy řízení toku Studijní cíl Tento studijní blok má za cíl pokračovat v základních prvcích jazyka Java. Konkrétně bude věnována pozornost příkazům pro řízení toku programu. Pro všechny tyto základní

Více

EVROPSKÝ SOCIÁLNÍ FOND. Úvod do PHP PRAHA & EU INVESTUJEME DO VAŠÍ BUDOUCNOSTI

EVROPSKÝ SOCIÁLNÍ FOND. Úvod do PHP PRAHA & EU INVESTUJEME DO VAŠÍ BUDOUCNOSTI EVROPSKÝ SOCIÁLNÍ FOND Úvod do PHP PRAHA & EU INVESTUJEME DO VAŠÍ BUDOUCNOSTI Úvod do PHP PHP Personal Home Page Hypertext Preprocessor jazyk na tvorbu dokumentů přípona: *.php skript je součást HTML stránky!

Více

Popis programovacího jazyka PL/SQL

Popis programovacího jazyka PL/SQL Zdeněk Pavlas Popis programovacího jazyka PL/SQL Kapitola 1 - Přehled V této kapitole jsou shrnuty hlavní vlastnosti PL/SQL, a je poukázáno na přednosti, které přinášejí. Jste seznámeni se základními koncepty,

Více

Čtvrtek 8. prosince. Pascal - opakování základů. Struktura programu:

Čtvrtek 8. prosince. Pascal - opakování základů. Struktura programu: Čtvrtek 8 prosince Pascal - opakování základů Struktura programu: 1 hlavička obsahuje název programu, použité programové jednotky (knihovny), definice konstant, deklarace proměnných, všechny použité procedury

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. - 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

Pascal. Katedra aplikované kybernetiky. Ing. Miroslav Vavroušek. Verze 7

Pascal. Katedra aplikované kybernetiky. Ing. Miroslav Vavroušek. Verze 7 Pascal Katedra aplikované kybernetiky Ing. Miroslav Vavroušek Verze 7 Proměnné Proměnná uchovává nějakou informaci potřebnou pro práci programu. Má ve svém oboru platnosti unikátní jméno. (Připadne, musí

Více

Tematický celek Proměnné. Proměnné slouží k dočasnému uchovávání hodnot během provádění aplikace Deklarace proměnných

Tematický celek Proměnné. Proměnné slouží k dočasnému uchovávání hodnot během provádění aplikace Deklarace proměnných Tematický celek 03 3.1 Proměnné Proměnné slouží k dočasnému uchovávání hodnot během provádění aplikace. 3.1.1 Deklarace proměnných Dim jméno_proměnné [As typ] - deklarace uvnitř procedury platí pouze pro

Více

SII - Informatika. 1. Atribut relace, jehož hodnota jednoznačně určuje prvek v jiné relaci, se nazývá:

SII - Informatika. 1. Atribut relace, jehož hodnota jednoznačně určuje prvek v jiné relaci, se nazývá: SII - Informatika Způsob vyhodnocení: Při vyhodnocení budou za nesprávné odpovědi strhnuty body. 1. Atribut relace, jehož hodnota jednoznačně určuje prvek v jiné relaci, se nazývá: a) sekundární klíč b)

Více

NPRG030 Programování I, 2010/11

NPRG030 Programování I, 2010/11 Podmínka = něco, co JE, nebo NENÍ splněno typ Boolean hodnoty: TRUE pravda FALSE lež domluva (optimistická): FALSE < TRUE když X, Y jsou (číselné) výrazy, potom X = Y X Y X < Y X > Y X = Y jsou

Více

10. Architektura klient/server a třívrstvá architektura

10. Architektura klient/server a třívrstvá architektura 10. Architektura klient/server a třívrstvá architektura 10.1. Varianty architektury... 3 10.2. Přínos architektury klient/server a třívrstvé architektury... 5 10.3. Podpora pro rozdělení zátěže v architektuře

Více

10. Architektura klient/server a třívrstvá architektura

10. Architektura klient/server a třívrstvá architektura 10. Architektura klient/server a třívrstvá architektura 10.1. Varianty architektury... 3 10.2. Přínos architektury klient/server a třívrstvé architektury... 5 10.3. Podpora pro rozdělení zátěže v architektuře

Více

Vyučovací hodina. 1vyučovací hodina: 2vyučovací hodiny: Opakování z minulé hodiny. Procvičení nové látky

Vyučovací hodina. 1vyučovací hodina: 2vyučovací hodiny: Opakování z minulé hodiny. Procvičení nové látky Vyučovací hodina 1vyučovací hodina: Opakování z minulé hodiny Nová látka Procvičení nové látky Shrnutí 5 min 20 min 15 min 5 min 2vyučovací hodiny: Opakování z minulé hodiny Nová látka Procvičení nové

Více

Kritéria hodnocení praktické maturitní zkoušky z databázových systémů

Kritéria hodnocení praktické maturitní zkoušky z databázových systémů Kritéria hodnocení praktické maturitní zkoušky z databázových systémů Otázka č. 1 Datový model 1. Správně navržený ERD model dle zadání max. 40 bodů teoretické znalosti konceptuálního modelování správné

Více

Distanční opora předmětu: Databázové systémy Tématický blok č. 8: Transact SQL Autor: RNDr. Jan Lánský, Ph.D.

Distanční opora předmětu: Databázové systémy Tématický blok č. 8: Transact SQL Autor: RNDr. Jan Lánský, Ph.D. Distanční opora předmětu: Databázové systémy Tématický blok č. 8: Transact SQL Autor: RNDr. Jan Lánský, Ph.D. Obsah kapitoly 1 Motivace 2 Základy syntaxe 3 Procedury a Funkce 4 Kurzory 5 Výjimky Studijní

Více

6. Příkazy a řídící struktury v Javě

6. Příkazy a řídící struktury v Javě 6. Příkazy a řídící struktury v Javě Příkazy v Javě Příkazy v Javě Řídicí příkazy (větvení, cykly) Přiřazovací příkaz = Řízení toku programu (větvení, cykly) Volání metody Návrat z metody - příkaz return

Více

NPRG030 Programování I, 2016/17 1 / :58:13

NPRG030 Programování I, 2016/17 1 / :58:13 NPRG030 Programování I, 2016/17 1 / 31 10. 10. 2016 10:58:13 Podmínka = něco, co JE, nebo NENÍ splněno typ Boolean hodnoty: TRUE pravda FALSE lež domluva (optimistická): FALSE < TRUE NPRG030 Programování

Více

Jazyk VHDL konstanty, signály a proměnné. Jazyk VHDL paralelní a sekvenční doména. Kurz A0B38FPGA Aplikace hradlových polí

Jazyk VHDL konstanty, signály a proměnné. Jazyk VHDL paralelní a sekvenční doména. Kurz A0B38FPGA Aplikace hradlových polí ČESKÉ VYSOKÉ UČENÍ TECHNICKÉ V PRAZE Fakulta elektrotechnická Ing. Radek Sedláček, Ph.D., katedra měření K13138 Jazyk VHDL konstanty, signály a proměnné Jazyk VHDL paralelní a sekvenční doména Kurz A0B38FPGA

Více

for (i = 0, j = 5; i < 10; i++) { // tělo cyklu }

for (i = 0, j = 5; i < 10; i++) { // tělo cyklu } 5. Operátor čárka, - slouží k jistému určení pořadí vykonání dvou příkazů - oddělím-li čárkou dva příkazy, je jisté, že ten první bude vykonán dříve než příkaz druhý. Např.: i = 5; j = 8; - po překladu

Více

Algoritmizace a programování. Ak. rok 2012/2013 vbp 1. ze 44

Algoritmizace a programování. Ak. rok 2012/2013 vbp 1. ze 44 Algoritmizace a programování Ak. rok 2012/2013 vbp 1. ze 44 Vladimír Beneš Petrovický K101 katedra matematiky, statistiky a informačních technologií vedoucí katedry E-mail: vbenes@bivs.cz Telefon: 251

Více

NPRG030 Programování I, 2015/16 1 / :25:32

NPRG030 Programování I, 2015/16 1 / :25:32 NPRG030 Programování I, 2015/16 1 / 21 22. 10. 2015 13:25:32 Podprogramy Příklad: Vytiskněte tabulku malé násobilky ve tvaru XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX X X 1 2 3 4 5 6 7 8 9 10 X

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

6. blok část C Množinové operátory

6. blok část C Množinové operátory 6. blok část C Množinové operátory Studijní cíl Tento blok je věnován problematice množinových operátorů a práce s množinovými operátory v jazyce SQL. Čtenáři se seznámí s operátory, UNION, a INTERSECT.

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

dovolují dělení velkých úloh na menší = dekompozice

dovolují dělení velkých úloh na menší = dekompozice Podprogramy dovolují dělení velkých úloh na menší = dekompozice Příklad: Vytiskněte tabulku malé násobilky ve tvaru XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX X X 1 2 3 4 5 6 7 8 9 10 X XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

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

Algoritmizace a programování

Algoritmizace a programování Algoritmizace a programování Řídicí struktury jazyka Java Struktura programu Příkazy jazyka Blok příkazů Logické příkazy Ternární logický operátor Verze pro akademický rok 2012/2013 1 Struktura programu

Více

Programovací jazyk. - norma PASCAL (1974) - implementace Turbo Pascal, Borland Pascal FreePascal Object Pascal (Delphi)

Programovací jazyk. - norma PASCAL (1974) - implementace Turbo Pascal, Borland Pascal FreePascal Object Pascal (Delphi) Programovací jazyk - norma PASCAL (1974) - implementace Turbo Pascal, Borland Pascal FreePascal Object Pascal (Delphi) Odlišnosti implementace od normy - odchylky např.: nepovinná hlavička programu odlišná

Více

Příkazy preprocesoru - Před překladem kódu překladačem mu předpřipraví kód preprocesor - Preprocesor vypouští nadbytečné (prázdné) mezery a řádky -

Příkazy preprocesoru - Před překladem kódu překladačem mu předpřipraví kód preprocesor - Preprocesor vypouští nadbytečné (prázdné) mezery a řádky - Příkazy preprocesoru - Před překladem kódu překladačem mu předpřipraví kód preprocesor - Preprocesor vypouští nadbytečné (prázdné) mezery a řádky - Preprocesor je možné ovládat pomocí příkazů - řádky začínající

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 programovacích jazyků (Java)

Úvod do programovacích jazyků (Java) Úvod do programovacích jazyků (Java) Michal Krátký Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2007/2008 c 2006 2008 Michal Krátký Úvod do programovacích

Více

2) Napište algoritmus pro vložení položky na konec dvousměrného seznamu. 3) Napište algoritmus pro vyhledání položky v binárním stromu.

2) Napište algoritmus pro vložení položky na konec dvousměrného seznamu. 3) Napište algoritmus pro vyhledání položky v binárním stromu. Informatika 10. 9. 2013 Jméno a příjmení Rodné číslo 1) Napište algoritmus pro rychlé třídění (quicksort). 2) Napište algoritmus pro vložení položky na konec dvousměrného seznamu. 3) Napište algoritmus

Více

Souhrn Apendixu A doporučení VHDL

Souhrn Apendixu A doporučení VHDL Fakulta elektrotechniky a informatiky Univerzita Pardubice Souhrn Apendixu A doporučení VHDL Práce ke zkoušce z předmětu Programovatelné logické obvody Jméno: Jiří Paar Datum: 17. 2. 2010 Poznámka k jazyku

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

PRŮBĚHOVÝ TEST Z PŘEDNÁŠEK

PRŮBĚHOVÝ TEST Z PŘEDNÁŠEK PRŮBĚHOVÝ TEST Z PŘEDNÁŠEK listopad 2009 souhrn v1 Červené dobře (nejspíš), modré možná Oracle Internet Directory OID: Databáze nemůže z OID přebírat seznam uživatelů *Databáze může získat z OID seznam

Více

DATABÁZOVÉ A INFORMAČNÍ SYSTÉMY

DATABÁZOVÉ A INFORMAČNÍ SYSTÉMY Databázové a informační systémy 1/9 DATABÁZOVÉ A INFORMAČNÍ SYSTÉMY Katedra informatiky FEI VŠB Technická univerzita Ostrava 2012/2013 Databázové a informační systémy 2/9 TABULKA ST U D E N T Pokud nebude

Více

DATABÁZOVÉ A INFORMAČNÍ SYSTÉMY

DATABÁZOVÉ A INFORMAČNÍ SYSTÉMY Databázové a informační systémy 1. Úvod, PL/SQL I 1/62 DATABÁZOVÉ A INFORMAČNÍ SYSTÉMY Michal Krátký, Radim Bača Katedra informatiky FEI VŠB Technická univerzita Ostrava 2012/2013 Databázové a informační

Více

Začínáme vážně programovat. Řídící struktury Přetypování Vstupně výstupní operace Vlastní tvorba programů

Začínáme vážně programovat. Řídící struktury Přetypování Vstupně výstupní operace Vlastní tvorba programů Začínáme vážně programovat Řídící struktury Přetypování Vstupně výstupní operace Vlastní tvorba programů Podmínky a cykly Dokončení stručného přehledu řídících struktur jazyka C. Složený příkaz, blok Pascalské

Více

Implementace LL(1) překladů

Implementace LL(1) překladů Překladače, přednáška č. 6 Ústav informatiky, FPF SU Opava sarka.vavreckova@fpf.slu.cz Poslední aktualizace: 30. října 2007 Postup Programujeme syntaktickou analýzu: 1 Navrhneme vhodnou LL(1) gramatiku

Více

Kritéria hodnocení praktické maturitní zkoušky z databázových systémů

Kritéria hodnocení praktické maturitní zkoušky z databázových systémů Kritéria hodnocení praktické maturitní zkoušky z databázových systémů Otázka č. 1 Datový model 1. Správně navržený ERD model dle zadání max. 40 bodů teoretické znalosti konceptuálního modelování správné

Více

Obsah. Předmluva 13 Zpětná vazba od čtenářů 14 Zdrojové kódy ke knize 15 Errata 15

Obsah. Předmluva 13 Zpětná vazba od čtenářů 14 Zdrojové kódy ke knize 15 Errata 15 Předmluva 13 Zpětná vazba od čtenářů 14 Zdrojové kódy ke knize 15 Errata 15 KAPITOLA 1 Úvod do programo vání v jazyce C++ 17 Základní pojmy 17 Proměnné a konstanty 18 Typy příkazů 18 IDE integrované vývojové

Více

Obsah přednášky. programovacího jazyka. Motivace. Princip denotační sémantiky Sémantické funkce Výrazy Příkazy Vstup a výstup Kontinuace Program

Obsah přednášky. programovacího jazyka. Motivace. Princip denotační sémantiky Sémantické funkce Výrazy Příkazy Vstup a výstup Kontinuace Program Denotační sémantika programovacího jazyka doc. Dr. Ing. Miroslav Beneš katedra informatiky, A-1007 59 732 4213 Obsah přednášky Princip denotační sémantiky Sémantické funkce Výrazy Příkazy Vstup a výstup

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

Vstupní požadavky, doporučení a metodické pokyny

Vstupní požadavky, doporučení a metodické pokyny Název modulu: Základy PHP Označení: C9 Stručná charakteristika modulu Modul je orientován na tvorbu dynamických stánek aktualizovaných podle kontextu volání. Jazyk PHP umožňuje velmi jednoduchým způsobem

Více

Maturitní otázky z předmětu PROGRAMOVÁNÍ

Maturitní otázky z předmětu PROGRAMOVÁNÍ Wichterlovo gymnázium, Ostrava-Poruba, příspěvková organizace Maturitní otázky z předmětu PROGRAMOVÁNÍ 1. Algoritmus a jeho vlastnosti algoritmus a jeho vlastnosti, formy zápisu algoritmu ověřování správnosti

Více

Úvod do programování - Java. Cvičení č.4

Úvod do programování - Java. Cvičení č.4 Úvod do programování - Java Cvičení č.4 1 Sekvence (posloupnost) Sekvence je tvořena posloupností jednoho nebo více příkazů, které se provádějí v pevně daném pořadí. Příkaz se začne provádět až po ukončení

Více

O datových typech a jejich kontrole

O datových typech a jejich kontrole .. O datových typech a jejich kontrole Programovací techniky doc. Ing. Jiří Rybička, Dr. ústav informatiky PEF MENDELU v Brně rybicka@mendelu.cz Typová kontrola Programovací techniky O datových typech

Více

VÝUKOVÝ MATERIÁL. Bratislavská 2166, 407 47 Varnsdorf, IČO: 18383874 www.vosassvdf.cz, tel. +420412372632 Číslo projektu

VÝUKOVÝ MATERIÁL. Bratislavská 2166, 407 47 Varnsdorf, IČO: 18383874 www.vosassvdf.cz, tel. +420412372632 Číslo projektu VÝUKOVÝ MATERIÁL Identifikační údaje školy Vyšší odborná škola a Střední škola, Varnsdorf, příspěvková organizace Bratislavská 2166, 407 47 Varnsdorf, IČO: 18383874 www.vosassvdf.cz, tel. +420412372632

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

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

VISUAL BASIC. Práce se soubory

VISUAL BASIC. Práce se soubory VISUAL BASIC Práce se soubory Práce se soubory 1/2 2 Vstupní data pro programy bývají uloženy do souborů Vstupy pro výpočet, nastavení vzhledu aplikace Výsledky práce programu je potřeba uchovat uložit

Více

24-2-2 PROMĚNNÉ, KONSTANTY A DATOVÉ TYPY TEORIE DATUM VYTVOŘENÍ: 23.7.2013 KLÍČOVÁ AKTIVITA: 02 PROGRAMOVÁNÍ 2. ROČNÍK (PRG2) HODINOVÁ DOTACE: 1

24-2-2 PROMĚNNÉ, KONSTANTY A DATOVÉ TYPY TEORIE DATUM VYTVOŘENÍ: 23.7.2013 KLÍČOVÁ AKTIVITA: 02 PROGRAMOVÁNÍ 2. ROČNÍK (PRG2) HODINOVÁ DOTACE: 1 24-2-2 PROMĚNNÉ, KONSTANTY A DATOVÉ TYPY TEORIE AUTOR DOKUMENTU: MGR. MARTINA SUKOVÁ DATUM VYTVOŘENÍ: 23.7.2013 KLÍČOVÁ AKTIVITA: 02 UČIVO: STUDIJNÍ OBOR: PROGRAMOVÁNÍ 2. ROČNÍK (PRG2) INFORMAČNÍ TECHNOLOGIE

Více

Sdílení dat mezi podprogramy

Sdílení dat mezi podprogramy Sdílení dat mezi podprogramy Datové objekty mohou být mezi podprogramy sdíleny pomocí ne-lokálních referenčních prostředí, která jsou vytvářena na základě æ explicitních modifikací (formální parametry

Více

4. lekce Přístup k databázi z vyššího programovacího jazyka

4. lekce Přístup k databázi z vyššího programovacího jazyka 4. lekce Přístup k databázi z vyššího programovacího jazyka Studijní cíl Tento blok popisuje základní principy přístupu k databázi z vyššího programovacího jazyka. Doba nutná k nastudování 2-3 hodiny Průvodce

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

Ú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

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

Obsah. Začínáme programovat v Ruby on Rails 9. Úvod 11. 1. Vítejte v Ruby 15. O autorovi 9 Poděkování 9

Obsah. Začínáme programovat v Ruby on Rails 9. Úvod 11. 1. Vítejte v Ruby 15. O autorovi 9 Poděkování 9 Začínáme programovat v Ruby on Rails 9 O autorovi 9 Poděkování 9 Úvod 11 Komu je kniha určena 11 Jak je kniha uspořádána 11 Co ke knize potřebujete 12 Konvence 12 Zdrojový kód 13 Poznámka redakce českého

Více

Embedded SQL v C/C++ úvod. Administrace Oracle Kateřina Opočenská

Embedded SQL v C/C++ úvod. Administrace Oracle Kateřina Opočenská Embedded SQL v C/C++ úvod Administrace Oracle Kateřina Opočenská Motivace potřeba začlenit komunikaci s databází do aplikace v nějakém vyšším programovacím jazyce řešení (na Oracle): a) OCI (Oracle Call

Více

8. lekce Úvod do jazyka C 3. část Základní příkazy jazyka C Miroslav Jílek

8. lekce Úvod do jazyka C 3. část Základní příkazy jazyka C Miroslav Jílek 8. lekce Úvod do jazyka C 3. část Základní příkazy jazyka C Miroslav Jílek 1/41 Základní příkazy Všechny příkazy se píšou malými písmeny! Za většinou příkazů musí být středník (;)! 2/41 Základní příkazy

Více

Objektově orientované programování

Objektově orientované programování 10. října 2011 Pragmatické informace Volitelný předmět, zápočet: zápočtový program(s dokumentací), aktivní účast na cvičení(body v CodExu), praktický test, zkouška: zkoušková písemka na objektový návrh

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

WSH Windows Script Hosting. OSY 2 Přednáška číslo 2 opravená verze z 15.10.2007

WSH Windows Script Hosting. OSY 2 Přednáška číslo 2 opravená verze z 15.10.2007 WSH Windows Script Hosting OSY 2 Přednáška číslo 2 opravená verze z 15.10.2007 Co je skript? Skriptování nástroj pro správu systému a automatizaci úloh Umožňuje psát skripty jednoduché interpretované programové

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

8 Třídy, objekty, metody, předávání argumentů metod

8 Třídy, objekty, metody, předávání argumentů metod 8 Třídy, objekty, metody, předávání argumentů metod Studijní cíl Tento studijní blok má za cíl pokračovat v základních prvcích jazyka Java. Konkrétně bude věnována pozornost třídám a objektům, instančním

Více

Sada 1 - Základy programování

Sada 1 - Základy programování S třední škola stavební Jihlava Sada 1 - Základy programování 07. Základní příkazy vstup a výstup hodnot Digitální učební materiál projektu: SŠS Jihlava šablony registrační číslo projektu:cz.1.09/1.5.00/34.0284

Více

Programování v C++, 2. cvičení

Programování v C++, 2. cvičení Programování v C++, 2. cvičení 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled 1 Operátory new a delete 2 3 Operátory new a delete minule

Více

2.1 Podmínka typu case Cykly Cyklus s podmínkou na začátku Cyklus s podmínkou na konci... 5

2.1 Podmínka typu case Cykly Cyklus s podmínkou na začátku Cyklus s podmínkou na konci... 5 Obsah Obsah 1 Řídicí struktury 1 2 Podmínka 1 2.1 Podmínka typu case......................... 2 3 Příkaz skoku 3 4 Cykly 4 4.1 Cyklus s podmínkou na začátku................... 4 4.2 Cyklus s podmínkou

Více

POSTUP PRO VYTVOŘENÍ STRUKTUR PRO UKLÁDÁNÍ RDF DAT V ORACLE

POSTUP PRO VYTVOŘENÍ STRUKTUR PRO UKLÁDÁNÍ RDF DAT V ORACLE POSTUP PRO VYTVOŘENÍ STRUKTUR PRO UKLÁDÁNÍ RDF DAT V ORACLE Upozornění: Pro práci s RDF Oracle daty je třeba mít nainstalován Oracle Spatial Resource Description Framework (RDF). 1. Vytvoření tabulkového

Více

Úvod do programovacích jazyků (Java)

Úvod do programovacích jazyků (Java) Úvod do programovacích jazyků (Java) Michal Krátký Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2007/2008 c 2006 2008 Michal Krátký Úvod do programovacích

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

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

5. POČÍTAČOVÉ CVIČENÍ

5. POČÍTAČOVÉ CVIČENÍ 5. POČÍTAČOVÉ CVIČENÍ Databáze Databázi si můžeme představit jako místo, kam se ukládají všechny potřebné údaje. Přístup k údajům uloženým v databázi obstarává program, kterému se říká Systém Řízení Báze

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

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

Zápis programu v jazyce C#

Zápis programu v jazyce C# Zápis programu v jazyce C# Základní syntaktická pravidla C# = case sensitive jazyk rozlišuje velikost písmen Tzv. bílé znaky (Enter, mezera, tab ) ve ZK překladač ignoruje každý příkaz končí ; oddělovač

Více

- znakové konstanty v apostrofech, např. a, +, (znak mezera) - proměnná zabírá 1 byte, obsahuje kód příslušného znaku

- znakové konstanty v apostrofech, např. a, +, (znak mezera) - proměnná zabírá 1 byte, obsahuje kód příslušného znaku Znaky - standardní typ char var Z, W: char; - znakové konstanty v apostrofech, např. a, +, (znak mezera) - proměnná zabírá 1 byte, obsahuje kód příslušného znaku - v TP (často i jinde) se používá kódová

Více

Základní pojmy. Úvod do programování. Základní pojmy. Zápis algoritmu. Výraz. Základní pojmy

Základní pojmy. Úvod do programování. Základní pojmy. Zápis algoritmu. Výraz. Základní pojmy Úvod do programování Michal Krátký 1,Jiří Dvorský 1 1 Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programování, 2004/2005 Procesor Procesorem je objekt, který vykonává algoritmem popisovanou

Více

1.1 Struktura programu v Pascalu Vstup a výstup Operátory a některé matematické funkce 5

1.1 Struktura programu v Pascalu Vstup a výstup Operátory a některé matematické funkce 5 Obsah Obsah 1 Programovací jazyk Pascal 1 1.1 Struktura programu v Pascalu.................... 1 2 Proměnné 2 2.1 Vstup a výstup............................ 3 3 Operátory a některé matematické funkce 5

Více

type Obdelnik = array [1..3, 1..4] of integer; var M: Obdelnik;

type Obdelnik = array [1..3, 1..4] of integer; var M: Obdelnik; Vícerozměrné pole type Obdelnik = array [1..3, 1..4] of integer; var M: Obdelnik; M[2,3] := 3145; - počet indexů není omezen (v praxi obvykle nejvýše tři) - více indexů pomalejší přístup k prvku (počítá

Více

Syntaktická analýza. Implementace LL(1) překladů. Šárka Vavrečková. Ústav informatiky, FPF SU Opava

Syntaktická analýza. Implementace LL(1) překladů. Šárka Vavrečková. Ústav informatiky, FPF SU Opava Implementace LL(1) překladů Ústav informatiky, FPF SU Opava sarka.vavreckova@fpf.slu.cz Poslední aktualizace: 6. ledna 2012 Postup Programujeme syntaktickou analýzu: 1 Navrhneme vhodnou LL(1) gramatiku

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

ALGORITMIZACE A PROGRAMOVÁNÍ

ALGORITMIZACE A PROGRAMOVÁNÍ Metodický list č. 1 Algoritmus a jeho implementace počítačovým programem Základním cílem tohoto tematického celku je vysvětlení pojmů algoritmus a programová implementace algoritmu. Dále je cílem seznámení

Více

Pseudonáhodná čísla = algoritmicky generovaná náhrada za náhodná čísla

Pseudonáhodná čísla = algoritmicky generovaná náhrada za náhodná čísla Pseudonáhodná čísla = algoritmicky generovaná náhrada za náhodná čísla Použití: - náhodnost při rozhodování např. ve hrách (výběr z více možných stejně dobrých tahů v dané pozici, házecí kostka) - generování

Více

ÚVOD DO DATABÁZÍ II (DISTANČNÍ VÝUKOVÁ OPORA)

ÚVOD DO DATABÁZÍ II (DISTANČNÍ VÝUKOVÁ OPORA) UČEBNÍ TEXTY OSTRAVSKÉ UNIVERZITY Přírodovědecká fakulta ÚVOD DO DATABÁZÍ II (DISTANČNÍ VÝUKOVÁ OPORA) Zdeňka Telnarová Ostravská univerzita OBSAH 1 Databázové struktury v Oracle... 4 1.1 Tabulky... 4

Více

1. lekce. do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme:

1. lekce. do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme: 1. lekce 1. Minimální program do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme: #include #include int main() { printf("hello world!\n"); return 0; 2.

Více

Logické operace. Datový typ bool. Relační operátory. Logické operátory. IAJCE Přednáška č. 3. může nabýt hodnot: o true o false

Logické operace. Datový typ bool. Relační operátory. Logické operátory. IAJCE Přednáška č. 3. může nabýt hodnot: o true o false Logické operace Datový typ bool může nabýt hodnot: o true o false Relační operátory pravda, 1, nepravda, 0, hodnoty všech primitivních datových typů (int, double ) jsou uspořádané lze je porovnávat binární

Více

1. lekce. do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme:

1. lekce. do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme: 1. lekce 1. Minimální program do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme: #include #include int main() { printf("hello world!\n"); return 0; 2.

Více

5a. Makra Visual Basic pro Microsoft Escel. Vytvořil Institut biostatistiky a analýz, Masarykova univerzita J. Kalina

5a. Makra Visual Basic pro Microsoft Escel. Vytvořil Institut biostatistiky a analýz, Masarykova univerzita J. Kalina 5a. Makra Visual Basic pro Microsoft Escel Vytvořil Institut biostatistiky a analýz, Masarykova univerzita J. Kalina Cyklické odkazy a iterativní výpočty Zde bude stránka o cyklických odkazech a iteracích.

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

Databázové systémy. Dotazovací jazyk SQL - III

Databázové systémy. Dotazovací jazyk SQL - III Databázové systémy Dotazovací jazyk SQL - III Vnořený select: kam všude Vytvoření kopie existující tabulky I Vytvoření kopie existující tabulky II Integritní omezení III SQL tříhodnotová logika SQL tříhodnotová

Více

Řídicí struktury. alg3 1

Řídicí struktury. alg3 1 Řídicí struktury Řídicí struktura je programová konstrukce, která se skládá z dílčích příkazů a předepisuje pro ně způsob provedení Tři druhy řídicích struktur: posloupnost, předepisující postupné provedení

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

PŘETĚŽOVÁNÍ OPERÁTORŮ

PŘETĚŽOVÁNÍ OPERÁTORŮ PŘETĚŽOVÁNÍ OPERÁTORŮ Jazyk C# podobně jako jazyk C++ umožňuje přetěžovat operátory, tj. rozšířit definice některých standardních operátorů na uživatelem definované typy (třídy a struktury). Stejně jako

Více

Paměť počítače. alg2 1

Paměť počítače. alg2 1 Paměť počítače Výpočetní proces je posloupnost akcí nad daty uloženými v paměti počítače Data jsou v paměti reprezentována posloupnostmi bitů (bit = 0 nebo 1) Připomeňme: paměť je tvořena řadou 8-mi bitových

Více

Databázové systémy a SQL

Databázové systémy a SQL Databázové systémy a SQL Lekce 2 Daniel Klimeš Autor, Název akce 1 CREATE TABLE Vytvoření tabulky (ORACLE) DDL příkazem v grafickém prostředí CREATE TABLE jmeno ( text VARCHAR2(200), cislo NUMBER(9,1),

Více