DB1 – 9. cvičení Optimalizace dotazu Konkurenční přístup a deadlock Indexace Transakce.

Slides:



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

KIV/ZIS Cvičení 6 SQL - SELECT.
SQL Další dotazy a pohledy
Základy jazyka SQL Jan Tichava
SQL: DDL v ORACLE CREATE TABLE jméno_tabulky (atribut datový_typ [DEFAULT][attribut_constraint] [, atribut datový_typ [DEFAULT] [attribut_constraint]],...
Jazyk SQL Ing. Zdena DOBEŠOVÁ. SQL Structured Query Language 1974 SEQUEL (Structured English Query Language) neprocedurální relační dotazovací jazyk norma.
Databázové systémy SQL Výběr dat.
YDASYS1 Ing. Monika Šimková.
Fakulta elektrotechniky a informatiky
Cvičení 03 SQL Select Ing. Pavel Bednář
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.
SQL Structured Query Language
Informatika pro ekonomy II přednáška 11
Fakulta elektrotechniky a informatiky
Architektury a techniky DS Tvorba efektivních příkazů I Přednáška č. 3 RNDr. David Žák, Ph.D. Fakulta elektrotechniky a informatiky
Databázové systémy 1 Cvičení č. 2 Fakulta elektrotechniky a informatiky Univerzita Pardubice.
Databázové systémy I Přednáška č. 5 RNDr. David Žák, Ph.D. Fakulta elektrotechniky a informatiky
1 BUMI Úvod do medicínské informatiky Počítačové cvičení č. 3 Ing. Vratislav Čmiel.
Temporální Databáze Jaroslav Dražan. Čím se budeme zabývat Proč je čas v DB důležitý Práce s časem pomocí klasického SQL Reprezentace časové domény Spojování.
Radek Špinka Přepínače MSSQL výběr.
Co takhle DOTAZY? OBSAH: Y 1) Co jsou to dotazy ve WinBase Y 2) Vytvoření jednoduchého dotazu Y 3) Použití dotazu.
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.
Školení správců II. Petr Pinkas RNDr. Vít Ochozka.
Cvičení 04 SQL Exists, Any, All Ing. Pavel Bednář
Fakulta elektrotechniky a informatiky
Databázové systémy I Cvičení č. 9 Fakulta elektrotechniky a informatiky Univerzita Pardubice 2013.
Optimalizace SQL dotazů
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 – základní pojmy Ing. Roman Danel, Ph.D.
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 II Přednáška č. X Ing. Tomáš Váňa, Ing. Jiří Zechmeister Fakulta elektrotechniky a informatiky
Čí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
Transakce Roman Špánek TU v Liberci Transakce Transakce = série příkazů čtení a zápisu do databáze A Atomic C Consistency I Isolation D Durability.
EBSCO - základní vyhledávání Lze nastavit jiné zobrazování výsledků.
Optimalizace SQL dotazů Michal Kopecký
Informatika II PAA DOTAZOVACÍ JAZYKY
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.
Architektury a techniky DS Cvičení č. 5 RNDr. David Žák, Ph.D. Fakulta elektrotechniky a informatiky
Databázové systémy 2 Cvičení č. 5 Fakulta elektrotechniky a informatiky Univerzita Pardubice.
Databázové systémy SQL Výběr dat.
Progress SQL92 Optimalizátor Jan Lánský
DBXplorer Systém pro vyhledávání nad relačními databází podle klíčových slov. zpracovala Margarita Vishnyakova.
SQL Další dotazy a pohledy Databázové systémy. Některé SQL příkazy mohou mít v sobě obsaženy další kompletní příkazy SELECT. Využijeme je tam, kde potřebujeme.
Lišta nástrojů Standard otevření, uložení a další manipulace se soubory (tj. projekty) načítání dat (mapových vrstev) „žluté plus“ změna měřítka odkaz.
Lišta nástrojů Standard otevření, uložení a další manipulace se soubory (tj. projekty) načítání dat (mapových vrstev) „žluté plus“ odkaz na další lišty.
SQL Structured Query Language
Databáze ● úložiště dat s definovaným přístupem ● typy struktury – strom, sekvence, tabulka ● sestává z uspořádaných záznamů ● databáze – struktura – záznam.
Dobývání znalostí z databází fulltext
SQL – příkaz SELECT Ing. Roman Danel, Ph.D.
Databázové systémy I Přednáška 5 Databázové systémy 1 – KIT/IDAS1
Databázové systémy I Přednáška 8 Databázové systémy 1 – KIT/IDAS1
Databázové systémy a SQL
Databázové systémy a SQL
Šablona 32 VY_32_INOVACE_038.ICT.34
[ START WITH podmínka ] CONNECT BY podmínka
Optimalizace SQL dotazů
Počítačová cvičení z předmětu Datové sklady
EBSCO - základní vyhledávání
Přednáška 7 SQL – JOIN.
Přednáška 9 Triggery.
Přednáška 8 INDEXY, POHLEDY.
Databázové systémy a SQL
Transkript prezentace:

DB1 – 9. cvičení Optimalizace dotazu Konkurenční přístup a deadlock Indexace Transakce

Optimalizace SQL dotazů Dvěma či více různými dotazy je možno obdržet stejná data Rychlost různých dotazů nemusí být stejná i přesto, že vracejí stejná data SQL je velmi flexibilní jazyk

Proč optimalizujeme? Jedná se o minimalizaci nákladů na: ◦zdrojový čas, ◦kapacitu paměti (prostor), ◦programátorskou práci. Snaha dosáhnout maximálního výkonu se stávajícími prostředky

Obecná pravidla Vyjmenovat sloupce Používat co nejméně klauzuli LIKE Používat co nejméně klauzule IN, NOT IN Používat klauzule typu LIMIT Na začátek dávat obecnější podmínky Výběr vhodného pořadí spojení Používat hinty Nastavit indexy

Vyjmenovat sloupce V SELECT dotazech nepoužívat v seznamu sloupců hvězdičku (*) Ve většině případů nepracujeme se všemi sloupci výsledku SELECT * FROM Lide SELECT Jmeno, Prijmeni FROM Lide

Používat co nejméně klauzuli LIKE Nedoporučuje se používat pro vyhledávání ve velkých textových polích (můžou obsahovat až několik GB textu) Zamyslet se, zda nejde vyhledávání provést jinou metodou

Používat co nejméně IN, NOT IN Vhodnější je použití příkazů WHERE a WHERE NOT EXISTS... WHERE Doprava IN ('Ford', 'Octavia', 'Seat', 'Peugeot');... WHERE Typ_Dopravy = 'Automobil';

Používat klauzule typu LIMIT V případech, kdy vybíráme např. nejstaršího člověka, můžeme použít dotaz: SELECT Jmeno, Prijmeni FROM Lide ORDER BY Vek DESC SELECT Jmeno, Prijmeni FROM Lide ORDER BY Vek DESC LIMIT 0,1

Na začátek dávat obecnější podmínky DS nejprve vyhledá záznamy, vyhovující první podmínce, z nich pak vybírá záznamy vyhovující druhé podmínce Snažíme se, aby systém vyřadil na začátku co nejvíce řádků; ty se pak již při další podmínce nezkoumají… SELECT Jmeno, Prijmeni FROM Lide WHERE Pohlavi = 'Z' AND Vek > 10

Výběr vhodného pořadí spojení 1) vyhnout se plnému prohledávání tabulky (pokud možno využít index) 2) efektivně vybírat takové indexy, které načtou z tabulky co nejméně záznamů 3) vybrat takové pořadí spojení ze všech možných pořadí, aby bylo spojeno co nejméně položek

Další rady Použití UNION ALL místo UNION Spojování tabulek s využitím indexů Vytváření indexů pro atributy podle nichž se třídí v klauzuli ORDER BY Provádění analýzy na indexovaných sloupcích

Indexy Procházení tabulky pomocí indexu trvá mnohem kratší dobu než procházení tabulky bez jeho použití. Změna indexů se zdá být nejlepším řešením pro optimalizaci, jelikož má větší sílu než změna SQL dotazu či změna dat. Samotné vytvoření indexů však nelze brát v úvahu jako univerzální řešení problému.

Takhle ne… CREATE TABLE Bugs ( bug_idSERIAL PRIMARY KEY, date_reportedDATE NOT NULL summaryVARCHAR(80) NOT NULL statusVARCHAR(10) NOT NULL hoursNUMERIC(9,2) INDEX(bug_id) INDEX(summary) INDEX(hours) INDEX(bug_id, date_reported, status) ); redundantní objemný nepotřebný zbytečně rozsáhlý

Konkurenční přístup a zámky Transactions Concurrency and Locking Lock Wait Deadlocks IBM 1.5 – Data Concurrency and Locking