Dotazovací jazyk SQL I.

Slides:



Advertisements
Podobné prezentace
Aplikační a programové vybavení
Advertisements

Základní obeznámení s jazykem SQL
Databázové systémy 2 Cvičení č. 8
Základy jazyka SQL Jan Tichava
A5M33IZS – Informační a znalostní systémy Dotazovací jazyk SQL - I.
SQL: DDL v ORACLE CREATE TABLE jméno_tabulky (atribut datový_typ [DEFAULT][attribut_constraint] [, atribut datový_typ [DEFAULT] [attribut_constraint]],...
Aplikační a programové vybavení
Jazyk SQL Ing. Zdena DOBEŠOVÁ. SQL Structured Query Language 1974 SEQUEL (Structured English Query Language) neprocedurální relační dotazovací jazyk norma.
Fakulta elektrotechniky a informatiky
Informační systémy Nástroje pro sběr dat, návrh a realizace databáze.
Další dotazy SQL Structured Query Language. Některé SQL příkazy mohou mít v sobě obsaženy další kompletní příkazy SELECT. Využijeme je tam, kde potřebujeme.
Databázové systémy Relační model.
Informatika pro ekonomy II přednáška 11
Databázové systémy 1 Cvičení č. 4 Fakulta elektrotechniky a informatiky Univerzita Pardubice.
Databázové systémy 1 Cvičení č. 2 Fakulta elektrotechniky a informatiky Univerzita Pardubice.
Databázové systémy 2 Cvičení č. 6 Ing. Tomáš Váňa Fakulta elektrotechniky a informatiky Univerzita Pardubice.
Fakulta elektrotechniky a informatiky
Databázové systémy 1 Cvičení č. 3 Fakulta elektrotechniky a informatiky Univerzita Pardubice.
1 BUMI Úvod do medicínské informatiky Počítačové cvičení č. 3 Ing. Vratislav Čmiel.
SQL Lukáš Masopust Historie  Předchůdcem databází byly papírové kartotéky  děrný štítek  1959 konference  1960 – vytvořen jazyk COBOL.
SQL Lukáš Masopust Historie  Předchůdcem databází byly papírové kartotéky  děrný štítek  1959 konference  1960 – vytvořen jazyk COBOL.
Radek Špinka Přepínače MSSQL výběr.
Databáze Jiří Kalousek.
SQL Přednáška DB1. Literatura CONNOLLY, T.M.-BEGG,C.E.-STRACHAN,A.D.: Database Systems – A Practial Approach to Design, Implementation and Management.
MySQL - Vytvoření nové tabulky  create table jméno_tabulky (jméno_položky typ_položky,... ) Přehled nejběžnějších datových typů Přehled nejběžnějších.
Databázové systémy Štěpán Šípal.
Databáze Úvod.
Databáze výhody a nevýhody Ing. Emilie Šeptáková
Databázové systémy II Přednáška č. 8 – Pohledy (Views)
Školení správců II. Petr Pinkas RNDr. Vít Ochozka.
Databázové systémy teorie a návrh relačních databázových systémů část II.
Relační databáze.
Vypracoval: Ondřej Dvorský Třída: VIII.A
Aplikační a programové vybavení
KIV/ZIS cvičení 6 Tomáš Potužák. Pokračování SQL Klauzule GROUP BY a dotazy nad více tabulkami Stáhnout soubor studenti_dotazy_sql.mdb.
Databázové systémy I Cvičení č. 6 Fakulta elektrotechniky a informatiky Univerzita Pardubice 2013.
Databázové systémy Přednáška č. 6.
SQL PVA Jan Hora. SQL „graficky“ Grafický vs. pravý SQL SELECT ORDED BY WHERE.
Rauer Luboš Kopic Petr Blažek Tomáš. Structured Query Language - dotazovací jazyk -> pracuje s dotazy - neprocedurální jazyk - mocný, ale přitom jednoduchý.
Databázové systémy 2 Cvičení č. 6 Ing. Tomáš Váňa Fakulta elektrotechniky a informatiky Univerzita Pardubice.
Číslo šablony: III/2 VY_32_INOVACE_P4_3.8 Tematická oblast: Aplikační software pro práci s informacemi II. Databáze – základy SQL Typ: DUM - kombinovaný.
Architektury a techniky DS Cvičení č. 9 RNDr. David Žák, Ph.D. Fakulta elektrotechniky a informatiky
Databázové systémy II Přednáška č. 9. Transakce je logická jednotka práce sestávající z jednoho nebo více SQL příkazů, které jsou atomické z hlediska.
Informatika II PAA DOTAZOVACÍ JAZYKY
Aplikační a programové vybavení
Aplikační a programové vybavení
Obchodní akademie, Ostrava-Poruba, příspěvková organizace Vzdělávací materiál/DUM VY_32_INOVACE_01B13 Autor Ing. Jiří Kalousek Období vytvoření březen.
Databázové systémy 2 Cvičení č. 5 Fakulta elektrotechniky a informatiky Univerzita Pardubice.
Základní obeznámení s jazykem SQL Databázové systémy.
Databázové systémy SQL Výběr dat.
Databázové Aplikace Slidy ke cvičení DBI026, část 3 KSI MFF UK Verze
Databázové systémy 2 Zkouška – 8:00. Příklad I - Funkce Vytvořte funkci ZK_DIFF_MIN_MAX (P_ZAM_ID NUMBER) RETURN VARCHAR2. Funkce může vracet.
Příkazy jazyka SQL ve VFP a na SQL Serveru
Databázové systémy I Cvičení č. 5 Fakulta elektrotechniky a informatiky Univerzita Pardubice 2013.
Databáze MS ACCESS 2010.
Dotazovací jazyk SQL I.
Databázové systémy a SQL
Z3104 Geodatabáze úvod.
Z3104 Geodatabáze úvod.
Databázové systémy a SQL
Databázové systémy a SQL
Šablona 32 VY_32_INOVACE_038.ICT.34
Počítačová cvičení z předmětu Datové sklady #1 Relační model dat
Dotazovací jazyk SQL I.
A5M33IZS – Informační a znalostní systémy
Přednáška 9 Triggery.
Přednáška 5 Úvod do SQL.
Databázové jazyky Jaroslav Pokorný FI BVŠP Bratislava
Databázové systémy a SQL
Transkript prezentace:

Dotazovací jazyk SQL I

Historický vývoj I

Historický vývoj II

Historický vývoj III

Další vývoj

Základní vlastnosti SQL (teoreticky) deklarativní jazyk staticky a silně typovaný jazyk multi-platformní SQL dotazy části jazyk pro definici dat (DDL) jazyk pro manipulaci dat (DML) jazyk pro definici přístupových práv (DCL) jazyk řízení transakcí (TCL) data uložena ve formě tabulek (skutečné nebo virtuální) fyzická struktura dat je odstíněná od programu/uživatele poloha/pořadí tabulek, sloupců a řádků v databázi není důležitá indexy (zrychlení dotazů, není explicitně v dotazech)

SQL – datové typy I

SQL – datové typy II

SQL – datové typy III

SQL – datové typy IV

SQL Jazyk pro definici dat CREATE vytvoření (tabulky, pohledu, sekvence, …) ALTER změna (sloupců tabulky, názvu indexu, …) DROP odstranění (tabulky, pohledu, …) TRUNCATE vyprázdnění (jedné nebo více tabulek, řádky jsou smazány, tabulky zůstávají) COMMENT definice nebo změna komentáře (tabulky, omezení, indexu, …) …

CREATE TABLE I PostgreSQL syntaxe CREATE TABLE (ukázka)

CREATE TABLE I PostgreSQL sémantika CREATE TABLE (ukázka) …

CREATE TABLE I Klíčové slovo nerozlišuje velikost konvence: VELKA PISMENA Identifikátor nerozlišuje velikost pokud není v “uvozovkách“ konvence: mala_pismena

CREATE TABLE I Jméno tabulky, která má být vytvořena Typ atributu PACKAGE PACKID PACKNAME PACKVER PACKTYPE PACKCOST Jméno tabulky, která má být vytvořena Typ atributu Jméno atributu DROP TABLE Computer Jméno tabulky, která má být zrušena Zruší existující tabulku daného jména.

CREATE TABLE II (integritní omezení atributu) Integritní omezení (atributu), specifikující, že daný atribut musí mít povinně vyplněnou hodnotu Vkládáme-li do tabulky nový řádek, nemusíme v obecném případě specifikovat hodnoty všech atributů (sloupců). Takový řádek pak bude mít ve sloupcích, pro něž jsme nezadali hodnotu, hodnotu uvedenu NULL. Pokud ovšem při vkládání řádku do tabulky neuvedeme hodnotu takového atributu, který má specifikováno integritní omezení NOT NULL, databázový engine odmítne takový řádek do tabulky vložit (chybová hláška nebo výjimka), protože by došlo k porušení příslušného integritního omezení.

CREATE TABLE III (integritní omezení atributu) Toto integritní omezení říká, že atribut CODE je primárním klíčem. Musí mít tudíž povinně zadanou hodnotu a tato hodnota musí být unikátní přes všechny řádky dané tabulky. Integritní omezení může být (ale nemusí a obvykle nebývá) pojmenováno. Šedivý text tedy může být vynechán.

CREATE TABLE IV (integritní omezení tabulky) V případě, že je primární klíč tvořen dvojicí, trojicí, ... atributů, nemůžeme tuto skutečnost vyjádřit integritním omezením atributu. Žádný z atributů podílejících se na primárním klíči totiž není sám o sobě primárním klíčem. V uvedeném příkladu je primárním klíčem dvojice atributů (TITLE, DateProd), což vyjádříme uvedeným integritním omezením tabulky. Unikátní přes všechny řádky nemá být hodnota každého z atributů TITLE, DateProd, ale jejich kombinace. PRIMARY KEY je jedním z možných integritních omezení tabulky. Nepovinné jméno integritního omezení tabulky. Integritní omezení je vhodné pojmenovávat, abychom je mohli popřípadě odstranit, pokud nevyhovují: ALTER TABLE Films DROP CONSTRAINT pk_const;

CREATE TABLE V (integritní omezení) 1 2 3 4 Atribut může mít zadáno více integritních omezení současně – v tomto případě je hodnota atributu povinná (NOT NULL) a unikátní (UNIQUE) přes všechny řádky. Integritní omezení může být zadáno i obecnou podmínkou, která musí být pro vkládaný řádek TRUE, jinak chyba. Libovolné integritní omezení atributu může být rovněž vyjádřeno jako integritní omezení tabulky. V tomto případě jsme mohli skutečnost, že os_cislo je primárním klíčem, rovnocenně vyjádřit integritním omezením atributu os_cislo. Toto je tzv. referenční integrita – bude probrána na samostatném slajdu. AND, OR, NOT <, >,<=, >=, =, <> or != a BETWEEN x AND y is equivalent to a >= x AND a <= y a NOT BETWEEN x AND y a < x OR a > y expression IS NULL expression IS NOT NULL

CREATE TABLE VI (integritní omezení) Pomocí speciálního druhu integritního omezení můžeme definovat i defaultní hodnotu atributu. Budeme-li vkládat řádek do tabulky vytvořené výše uvedeným příkazem a neuvede- me-li přitom hodnotu sloupce kredity, nezústane tento sloupec nevyplněn (NULL), ale bude mít hodnotu 2. id2 int NOT NULL DEFAULT 4

CREATE TABLE VII (generování hodnot) 1 1 Nejprve definujeme tzv. sekvenci. V daném případě jsme ji pojmenovali distrib_prim. Při vkládání nového řádku bude chtít integritní omezení DEFAULT přiřadit sloupci did vkládaného řádku hodnotu. Tuto hodnotu zjistí vyhodnocením funkce nextval(), jež ovšem vygeneruje nový (ještě neexistující) prvek sekvence distrib_prim. Jako výsledek bude mít každý řádek vygenerovanou unikátní hodnotu sloupce did. constants (literals): numbers, strings in ‘’ Toto není SQL standard, ale syntax DB systému ProgreSQL. Generování hodnot bylo standardizováno až v SQL2006.

CREATE TABLE VII (generování hodnot) CREATE TABLE customer_orders_t ( order_id INTEGER NOT NULL GENERATED ALWAYS AS IDENTITY (START WITH 1 INCREMENT BY 1 MINVALUE 1 NO MAXVALUE NO CYCLE NO CACHE ORDER), order_date DATE NOT NULL, PRIMARY KEY (order_date, order_id)); Generování hodnot dle SQL2006.

Přidání schématu

Změna struktury databáze

Vyprázdnění tabulky, komentáře

SQL Jazyk pro manipulaci s daty INSERT vložení dat do databáze UPDATE upravení dat v databázi DELETE mazání dat v databázi SELECT získání dat z databáze …

INSERT INTO Seznam hodnot Jméno tabulky Jméno tabulky Seznam atributů

Změna obsahu databáze

Změna obsahu databáze

REFERENČNÍ INTEGRITA I

REFERENČNÍ INTEGRITA II

REFERENČNÍ INTEGRITA III Modifikátory CASCADE, RSTRICT, SET NULL, SET DEFAULT se v sekcích ON UPDATE a ON DELETE nastavují nezávisle.

SELECT I

SELECT II

SELECT III

SELECT IV

SELECT V (Aritmetické operátory )

SELECT VI SELECT Vi bude 11.3.2010

SELECT VII (třídění)