Bazy danych 8. Widoki i wyzwalacze. P. F. Góra
|
|
- Katarzyna Kuczyńska
- 8 lat temu
- Przeglądów:
Transkrypt
1 Bazy danych 8. Widoki i wyzwalacze P. F. Góra
2 I. Widoki, AKA Perspektywy W SQL tabela, która utworzono za pomoca zapytania CREATE TABLE, nazywa się tabela podstawowa (base table). przez system operacyjny. Jej struktura i dane przechowywane sa Wynik każdego zapytania SELECT też, formalnie, jest tabela. Tabelę taka nazywa się tabela pochodna (derived table). Widokiem (lub perspektywa) nazywam trwała definicję tabeli pochodnej, która to definicja przechowywana jest w bazie danych. Copyright c P. F. Góra 8 2
3 Jak tworzymy widoki? CREATE VIEW nazwa AS SELECT treść zapytania select; Copyright c P. F. Góra 8 3
4 Przykład Tworzymy następujace tabele: mysql> CREATE TABLE arabic -> (i INT UNSIGNED NOT NULL, b VARCHAR(8)) CHARSET=cp1250; Query OK, 0 rows affected (0.87 sec) mysql> CREATE TABLE roman (i INT UNSIGNED NOT NULL, r VARCHAR(4)); Query OK, 0 rows affected (0.42 sec) mysql> SET CHARSET cp1250; Query OK, 0 rows affected (0.04 sec) mysql> INSERT INTO arabic VALUES -> (1, jeden ),(2, dwa ),(3, trzy ),(4, cztery ),(5, pięć ); Query OK, 5 rows affected (0.13 sec) Records: 5 Duplicates: 0 Warnings: 0 mysql> INSERT INTO roman VALUES -> (1, I ),(2, II ),(3, III ),(4, IV ); Query OK, 4 rows affected (1.17 sec) Records: 4 Duplicates: 0 Warnings: 0 Copyright c P. F. Góra 8 4
5 mysql> SELECT * FROM arabic; i b 1 jeden 2 dwa 3 trzy 4 cztery 5 pięć 5 rows in set (0.00 sec) mysql> SELECT * FROM roman; i r I 2 II 3 III 4 IV rows in set (0.00 sec) Copyright c P. F. Góra 8 5
6 Tworzymy najprostszy widok mysql> CREATE VIEW v1 -> AS SELECT * FROM arabic; Query OK, 0 rows affected (1.14 sec) Tak utworzony widok jest w gruncie rzeczy aliasem tabeli. mysql> SELECT * FROM v1; i b 1 jeden 2 dwa 3 trzy 4 cztery 5 pięć 5 rows in set (1.13 sec) Copyright c P. F. Góra 8 6
7 Widoki można tworzyć na podstawie widoków. Wyrażenie SELECT w definicji widoku może zawierać klauzulę WHERE. Można brać tylko wybrane kolumny. Można nadawać im aliasy. mysql> CREATE VIEW v2 -> AS SELECT b AS napis FROM v1 -> WHERE i > 3; Query OK, 0 rows affected (0.15 sec) mysql> SELECT * FROM v2; napis cztery pięć rows in set (0.05 sec) Copyright c P. F. Góra 8 7
8 Underlying tables Tabele, których użyto do zdefiniowania widoku, sa nazywane underlying tables. Widok v1 ma jedna underlying table: arabic. Widok v2 ma dwie underlying tables: tabelę arabic oraz widok v1. Copyright c P. F. Góra 8 8
9 Widoki a zmiana underlying table Widoki reaguja na zmianę danych w tabelach, których użyto do ich stworzenia: mysql> INSERT INTO arabic VALUES(6, sześć ); Query OK, 1 row affected (0.43 sec) mysql> SELECT * FROM v2; napis cztery pięć sześć rows in set (0.38 sec) Copyright c P. F. Góra 8 9
10 Widoki nie reaguja na zmianę definicji tabeli, o ile nie narusza ona integralności widoku. mysql> ALTER TABLE arabic ADD COLUMN (x CHAR(1) DEFAULT X ); Query OK, 6 rows affected (4.51 sec) Records: 6 Duplicates: 0 Warnings: 0 mysql> SELECT * FROM arabic WHERE i>4; i b x pięć X 6 sześć X rows in set (0.89 sec) mysql> SELECT * FROM v1 WHERE i>4; i b 5 pięć 6 sześć 2 rows in set (0.00 sec) Copyright c P. F. Góra 8 10
11 Można tworzyć całkiem skomplikowane widoki mysql> CREATE VIEW lewy -> AS SELECT arabic.i AS i, b, r FROM arabic LEFT JOIN roman -> ON arabic.i=roman.i; Query OK, 0 rows affected (1.23 sec) mysql> SELECT * FROM lewy; i b r jeden I 2 dwa II 3 trzy III 4 cztery IV 5 pięć 6 sześć rows in set (0.18 sec) Copyright c P. F. Góra 8 11
12 Po co widoki? mysql> CREATE TABLE Ceny -> (ProducentId SMALLINT UNSIGNED NOT NULL, -> ProduktId SMALLINT UNSIGNED NOT NULL, -> Cena DECIMAL(10,2) NOT NULL, -> PRIMARY KEY(ProducentId, ProduktId)); mysql> CREATE TABLE Dostawy -> (NrDostawy INT UNSIGNED NOT NULL PRIMARY KEY, -> ProducentId SMALLINT UNSIGNED NOT NULL, -> ProduktId SMALLINT UNSIGNED NOT NULL, -> Ilosc INT UNSIGNED NOT NULL); mysql> CREATE VIEW ksiegowosc -> AS SELECT ProducentID, Ilosc*Cena AS Kwota -> FROM Dostawy NATURAL JOIN Ceny; mysql> CREATE VIEW produkcja -> AS SELECT ProduktId, SUM(Ilosc) AS Zapas -> FROM Dostawy -> GROUP BY ProduktId; W bazie zapamiętane zostana tylko definicje poszczególnych kolumn widoków, nie zaś wartości! Różni użytkownicy bazy chca/mog a/powinni mieć różny dostęp do tych samych danych źródłowych. Copyright c P. F. Góra 8 12
13 Definiowanie widoków pozwala na przechowywanie całkiem złożonych definicji w bazie danych i późniejsze wykorzystywanie ich w zapytaniach. Jest to szczególnie wygodne gdy z ta sama baza współpracuja różne aplikacje. Copyright c P. F. Góra 8 13
14 Widoki modyfikowalne Niektóre widoki sa modyfikowalne zmiana danych w widoku powoduje zmianę danych w underlying tables. mysql> UPDATE v2 SET napis="six" WHERE napis LIKE "sz%"; Query OK, 1 row affected (1.33 sec) Rows matched: 1 Changed: 1 Warnings: 0 mysql> SELECT * FROM arabic; i b x jeden X 2 dwa X 3 trzy X 4 cztery X 5 pięć X 6 six X rows in set (0.00 sec) Copyright c P. F. Góra 8 14
15 Ale... mysql> INSERT INTO v2 VALUES ( siedem ); ERROR 1423 (HY000): Field of view widoki.v2 underlying table doesn t have a default value Nie można dodać lub zmienić wiersza widoku modyfikowalnego, jeżeli zmiana taka naruszałaby więzy integralności underlying tables. Gdyby kolumna i tabeli arabic była określona jako AUTO INCREMENT lub też gdyby nie była określona jako NOT NULL, powyższe wstawienie wiersza do widoku zadziałałoby. Jeżeli zatem chcemy udostępniać użytkownikom (aplikacjom) widoki, które maja być modyfikowalne, trzeba dobrze przemyśleć strukturę całej bazy. Copyright c P. F. Góra 8 15
16 Widoki niemodyfikowalne Niektóre widoki sa z założenia niemodyfikowalne: Niemodyfikowalne sa te, które w liście SELECT zawieraja UNION, UNION ALL, DISTINCT, DISTINCTROW, inny widok niemodyfikowalny lub podzapytanie. Podzapytania w widokach W MySQL widoki nie moga zawierać podzapytań, ale o ile podzapytania nie sa skorelowane, problem da się obejść! Jak? tworzac widoki, które spełniaja rolę podzapytań. W ten sposób można tworzyć bardzo złożone widoki. Copyright c P. F. Góra 8 16
17 Przykład: W pewnej bazie istnieja tabele mysql> DESCRIBE Studenci; Field Type Null Key Default Extra nr tinyint(3) unsigned NO PRI auto_increment Imie varchar(16) NO MUL Nazwisko varchar(16) NO mysql> DESCRIBE Bazy; Field Type Null Key Default Extra nr tinyint(3) unsigned NO PRI data date NO PRI OK char(2) YES OK Istnieja też tabele Metnum oraz Szeregi, o strukturze takiej samej, jak tabela Bazy. Copyright c P. F. Góra 8 17
18 Teraz możemy utworzyć widoki mysql> CREATE VIEW KtoBazy AS -> SELECT Nr, COUNT(*) AS C FROM Bazy WHERE OK="OK" GROUP BY Nr; mysql> CREATE VIEW KtoMetnum AS -> SELECT Nr, COUNT(*) AS C FROM Metnum WHERE OK="OK" GROUP BY Nr; mysql> CREATE VIEW KtoSzeregi AS -> SELECT Nr, COUNT(*) AS C FROM Szeregi WHERE OK="OK" GROUP BY Nr; mysql> CREATE VIEW KtoIle AS -> SELECT Imie, Nazwisko, KtoBazy.C AS Bazy, KtoMetnum.C AS Metnum, -> KtoSzeregi.C AS Szeregi -> FROM Studenci -> LEFT JOIN KtoBazy USING (Nr) -> LEFT JOIN KtoMetnum USING (Nr) -> LEFT JOIN KtoSzeregi USING (Nr) -> ORDER BY Nazwisko; Copyright c P. F. Góra 8 18
19 mysql> SELECT * FROM KtoIle LIMIT 6; Imie Nazwisko Bazy Metnum Szeregi Karol Adamczyk 2 NULL 2 Mateusz Armatys 1 NULL NULL Katarzyna Bąk NULL 4 NULL Rafał Baranowski NULL 4 NULL Paweł Buczkowski NULL NULL NULL Kamila Czaplicka NULL 4 NULL rows in set (0.00 sec) Copyright c P. F. Góra 8 19
20 Usuwanie wierszy z widoków Niekiedy z widoków modyfikowalnych można usuwać wiersze mianowicie wtedy, gdy SQL potrafi przetłumaczyć zapytanie usuwajace wiersze z widoku na zapytanie (zapytania) usuwajace wiersze z underlying table(s). mysql> DELETE FROM v2 WHERE napis="pięć"; Query OK, 1 row affected (1.24 sec) mysql> SELECT * FROM arabic; i b x jeden X 2 dwa X 3 trzy X 4 cztery X 6 six X rows in set (0.00 sec) Copyright c P. F. Góra 8 20
21 Ale... mysql> SELECT * FROM lewy; i b r jeden I 2 dwa II 3 trzy III 4 cztery IV 6 six rows in set (1.10 sec) mysql> DELETE FROM LEWY WHERE r= I ; ERROR 1395 (HY000): Can not delete from join view widoki.lewy Copyright c P. F. Góra 8 21
22 Więz CHECK w widokach CREATE VIEW nazwa AS SELECT treść zapytania select WHERE warunek [WITH [CASCADED LOCAL] CHECK OPTION]; Jeśli w zapytaniu tworzacym widok jest klauzula WHERE, więz CHECK uniemożliwi takie dodanie/zmodyfikowanie danych do widoku, które naruszałoby tę klauzulę. CASCADED i LOCAL maja znaczenie jeśli widok tworzony jest na podstawie innych widoków. Jeżeli wybierzemy CASCADED, klauzule WHERE podwidoków też sa sprawdzane, nawet jeśli nie nałożono na nie jawnie więzu CHECK. Copyright c P. F. Góra 8 22
23 Przykład mysql> CREATE VIEW v3 -> AS SELECT i, b FROM arabic -> WHERE i < 6; Query OK, 0 rows affected (1.13 sec) mysql> SELECT * FROM v3; i b 1 jeden 2 dwa 3 trzy 4 cztery 4 rows in set (0.00 sec) mysql> CREATE VIEW v4 -> AS SELECT i, b FROM arabic -> WHERE i < 6 -> WITH CHECK OPTION; Query OK, 0 rows affected (0.00 sec) mysql> SELECT * FROM v4; i b 1 jeden 2 dwa 3 trzy 4 cztery 4 rows in set (0.00 sec) Na tym etapie nie ma różnicy klauzula WHERE wybrała odpowiednie wiersze. Copyright c P. F. Góra 8 23
24 mysql> INSERT INTO v3 VALUES (7, siedem ); Query OK, 1 row affected (1.10 sec) mysql> SELECT * FROM v3; i b 1 jeden 2 dwa 3 trzy 4 cztery 4 rows in set (0.01 sec) mysql> INSERT INTO v4 VALUES (8, osiem ); ERROR 1369 (HY000): CHECK OPTION failed widoki.v4 Zawartość widoku v3 nie zmieniła się, ale pozwolił on na modyfikację underlying table, co możnaby sprawdzić wykonujac zapytanie SELECT * FROM arabic. Widok v4, z klauzula CHECK, na to nie pozwolił. Copyright c P. F. Góra 8 24
25 Widoki dyndajace Jeżeli usuniemy tabelę, nie usuniemy zaś opartych na niej widoków, lub też tak zmodyfikujemy tabelę, że definicja widoku straci sens, dostaniemy widoki dyndajace (dangling views). Widoki sa wypisywane na liście SHOW TABLES; mysql> SHOW TABLES; Tables_in_widoki arabic ceny dostawy ksiegowosc lewy produkcja roman v1 v2 v3 v rows in set (1.12 sec) Copyright c P. F. Góra 8 25
26 Aby dowiedzieć się czy dana tabela lub widok nie sa uszkodzone, dajemy polecenie mysql> CHECK TABLE roman; Table Op Msg_type Msg_text widoki.roman check status OK row in set (1.23 sec) mysql> CHECK TABLE lewy; Table Op Msg_type Msg_text widoki.lewy check status OK row in set (0.16 sec) W tym momencie wszystko jest w porzadku. Copyright c P. F. Góra 8 26
27 Ale... mysql> ALTER TABLE roman DROP COLUMN r; Query OK, 4 rows affected (1.88 sec) Records: 4 Duplicates: 0 Warnings: 0 mysql> CHECK TABLE lewy; Table Op Msg_type Msg_text widoki.lewy check error View widoki.lewy references invalid table(s) or column(s) or function(s) or definer/invoker of view lack rights to use them row in set (0.02 sec) mysql> DROP VIEW lewy; Query OK, 0 rows affected (0.01 sec) Copyright c P. F. Góra 8 27
28 Widoki zmaterializowane Widoki sa wirtualnymi tabelami, zawierajacymi rezultaty zapytań same nie przechowuja żadnych danych. Zdarzaja się jednak sytuacje, w których przydatne może być fizyczne przechowywanie danych z widoku. Takie widoki nazywamy widokami zmatrializowanymi (ang.materialized views). W ten sposób możemy tworzyć lokalna kopię danych, będacych wynikiem zapytania zadanego tabeli (tabelom) zlokalizowanej na odległym serwerze lub, jeszcze częściej, w systemach rozproszonych, w których różne części danych przechowywane sa na różnych serwerach. Przy powtórnym odwołaniu się do takiego widoku, korzystamy z kopii lokalnej, bez konieczności realizowania kosztownej i czasochłonnej komunikacji przez sieć. Od czasu do czasu widok taki odświeżamy aby zapewnić aktualność danych. Może się zdarzyć, że dane na odległym serwerze zostana zmienione zanim przeprowadzimy odświeżenie widoku, ale per saldo może i tak Copyright c P. F. Góra 8 28
29 to być opłacalne, zwłaszcza jeśli komunikacja jest powolna, a procent nieaktualnych danych niewielki. Korzystanie z widoków zmaterializowanych zmniejsza konieczność korzystania z sieci w systemach rozległych za cenę ryzyka, iż jakaś część danych nie będzie aktualna. MySQL nie implementuje widoków zmaterializowanych, ale można to obejść za pomoca wyzwalaczy i procedur składowanych patrz na przykład Copyright c P. F. Góra 8 29
30 II. Wyzwalacze (triggers) Wyzwalacze sa procedurami wykonywanymi automatycznie po zmianie zawartości wskazanej tabeli. CREATE TRIGGER nazwa wyzwalacza {BEFORE AFTER } {INSERT UPDATE DELETE } ON nazwa tabeli FOR EACH ROW wywoływane wyrażenie SQL; Copyright c P. F. Góra 8 30
31 mysql> CREATE TRIGGER tabela_trig -> BEFORE UPDATE ON tabela -> FOR EACH ROW -> BEGIN -> = OLD.w; -> = NEW.w; -> END; // Query OK, 0 rows affected (1.41 sec) mysql> UPDATE tabela SET W = W + 8 -> WHERE K = 1; Query OK, 1 row affected (1.40 sec) Rows matched: 1 Changed: 1 Warnings: 0 @n row in set (0.06 sec) Kwalifikatory OLD, NEW odnosza się do zawartości tabeli przed zmiana i po zmianie. Przy INSERT legalny jest tylko NEW, przy DELETE tylko OLD, przy UPDATE oba. Copyright c P. F. Góra 8 31
32 Wyzwalacze moga odwoływać się tylko do trwałych tabel podstawowych (nie do widoków ani tabel tymczasowych). Każda tabela może mieć co najwyżej jeden wyzwalacz z określona kombinacja BEFORE AFTER + INSERT UPDATE DELETE. Wyzwalacz INSERT jest uruchamiany także przez LOAD DATA. Wyzwalacze UPDATE, DELETE nie sa uruchamiane przez zapytania usuwajace tabele lub modyfikujace jej schemat. Wyzwalacze nie sa uruchamiane przez zdarzenia kaskadowe wywoływane przez klucze obce. Zgodnie ze standardem SQL, możliwe jest definiowanie wyzwalaczy bez klauzuli FOR EACH ROW taki wyzwalacz wywoływany jest raz po każdym zapytaniu wstawiajacym/modyfikuj acym/usuwaj acym dane, nie zaś dla każdego wstawianego/modyfikowanego/usuwanego wiersza. Ta cecha nie jest zaimplementowana w MySQL. Copyright c P. F. Góra 8 32
Bazy danych 10. SQL Widoki
Bazy danych 10. SQL Widoki P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2005/06 Widoki, AKA Perspektywy W SQL tabela, która utworzono za pomoca zapytania CREATE TABLE, nazywa się tabela
Bazy danych 7. Widoki i wyzwalacze. P. F. Góra
Bazy danych 7. Widoki i wyzwalacze P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2017 Widoki, AKA Perspektywy W SQL tabela, która utworzono za pomoca zapytania CREATE TABLE, nazywa się tabela podstawowa
Bazy danych 10. Widoki, procedury składowane, kursory i wyzwalacze. P. F. Góra
Bazy danych 10. Widoki, procedury składowane, kursory i wyzwalacze P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2009 I. Widoki, AKA Perspektywy W SQL tabela, która utworzono za pomoca zapytania CREATE
Bazy danych 10. SQL Widoki, procedury składowane, kursory i wyzwalacze
Bazy danych 10. SQL Widoki, procedury składowane, kursory i wyzwalacze P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2007/08 I. Widoki, AKA Perspektywy W SQL tabela, która utworzono za
Bazy danych 7. SQL podstawy
Bazy danych 7. SQL podstawy P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2005/06 Structured Query Language Używane standardy: SQL92 SQL99 SQL:2003 Żaden dostawca nie jest w pełni zgodny
Bazy danych 6. Klucze obce. P. F. Góra
Bazy danych 6. Klucze obce P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2018 Dygresja: Metody przechowywania tabel w MySQL Tabele w MySQL moga być przechowywane na kilka sposobów. Sposób ten (żargonowo:
Bazy Danych i Usługi Sieciowe
Bazy Danych i Usługi Sieciowe Ćwiczenia I Paweł Daniluk Wydział Fizyki Jesień 2011 P. Daniluk (Wydział Fizyki) BDiUS ćw. I Jesień 2011 1 / 15 Strona wykładu http://bioexploratorium.pl/wiki/ Bazy_Danych_i_Usługi_Sieciowe_-_2011z
Bazy danych i usługi sieciowe
Bazy danych i usługi sieciowe Ćwiczenia I Paweł Daniluk Wydział Fizyki Jesień 2014 P. Daniluk (Wydział Fizyki) BDiUS ćw. I Jesień 2014 1 / 16 Strona wykładu http://bioexploratorium.pl/wiki/ Bazy_danych_i_usługi_sieciowe_-_2014z
Bazy danych 5. Samozłaczenie SQL podstawy
Bazy danych 5. Samozłaczenie SQL podstawy P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2007/08 Przykład kolejowy Tworzymy bazę danych zawierajac a (uproszczony) rozkład jazdy pociagów
Bazy danych 4. SQL podstawy. P. F. Góra
Bazy danych 4. SQL podstawy P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2012 Structured Query Language Używane standardy: SQL92 SQL99 SQL:2003 SQL:2006 (dialekt) SQL:2008 (dialekt) SQL:2011 (dialekt)
Wprowadzenie. Tworzenie widoków
Widoki Wprowadzenie...2 Tworzenie widoków...2 Złączenie zewnętrzne w definicji widoków...4 Porządkowanie danych przez widoki...5 Modyfikowanie danych przez widoki...6 Ograniczenie zakresu modyfikowania
Paweł Rajba pawel@ii.uni.wroc.pl http://www.itcourses.eu/
Paweł Rajba pawel@ii.uni.wroc.pl http://www.itcourses.eu/ Wprowadzenie Historia i standardy Podstawy relacyjności Typy danych DDL tabele, widoki, sekwencje zmiana struktury DML DQL Podstawy, złączenia,
E.14 Bazy Danych cz. 18 SQL Funkcje, procedury składowane i wyzwalacze
Funkcje użytkownika Tworzenie funkcji Usuwanie funkcji Procedury składowane Tworzenie procedur składowanych Usuwanie procedur składowanych Wyzwalacze Wyzwalacze a ograniczenia i procedury składowane Tworzenie
Ćwiczenia laboratoryjne nr 11 Bazy danych i SQL.
Prezentacja Danych i Multimedia II r Socjologia Ćwiczenia laboratoryjne nr 11 Bazy danych i SQL. Celem ćwiczeń jest poznanie zasad tworzenia baz danych i zastosowania komend SQL. Ćwiczenie I. Logowanie
Bazy danych 9. SQL Klucze obce Transakcje
Bazy danych 9. SQL Klucze obce Transakcje P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2005/06 Klucze obce Klucze obce powiazanie indeksowanej kolumny jakiejś tabeli z indeksowana kolumna
Bazy danych 7. SQL dalsze możliwości. Grupowanie.
Bazy danych 7. SQL dalsze możliwości. Grupowanie. P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2005/06 MySQL i programowanie wsadowe C:\wyklady\bazy> mysql < nazwa pliku C:\wyklady\bazy>
Wykład 8. SQL praca z tabelami 5
Wykład 8 SQL praca z tabelami 5 Podzapytania to mechanizm pozwalający wykorzystywać wyniki jednego zapytania w innym zapytaniu. Nazywane często zapytaniami zagnieżdżonymi. Są stosowane z zapytaniami typu
Bazy danych 11. SQL Procedury składowane, kursory i wyzwalacze
Bazy danych 11. SQL Procedury składowane, kursory i wyzwalacze P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2005/06 I. Procedury składowane (stored procedures) Procedury składowane stanowia
Bazy danych 6. Podzapytania i grupowanie. P. F. Góra
Bazy danych 6. Podzapytania i grupowanie P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2012 Podzapytania Podzapytania pozwalaja na tworzenie strukturalnych podzapytań, co umożliwia izolowanie poszczególnych
Bazy danych 4. SQL- podstawy
Bazy danych 4. SQL- podstawy P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2017/18 SQL - Structured Query Language Interpretowany język programowania. Jego polecenia tradycyjnie nazywane sa zapytaniami
Bazy danych 9. Klucze obce Transakcje. P. F. Góra
Bazy danych 9. Klucze obce Transakcje P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2009 Dygresja: Metody przechowywania tabel w MySQL Tabele w MySQL moga być przechowywane na kilka sposobów. Sposób
Pawel@Kasprowski.pl Bazy danych. Bazy danych. Zapytania SELECT. Dr inż. Paweł Kasprowski. pawel@kasprowski.pl
Bazy danych Zapytania SELECT Dr inż. Paweł Kasprowski pawel@kasprowski.pl Przykład HAVING Podaj liczebność zespołów dla których najstarszy pracownik urodził się po 1940 select idz, count(*) from prac p
Wyzwalacze (triggery) Przykład
Wyzwalacze (triggery) Trigger jest obiektem związanym z tablicą, który aktywuje się gdy do tablicy następuje odpowiednie zapytanie. W poniższym przykładzie definiujemy tablicę, a następnie trigger związany
Hurtownia Świętego Mikołaja projekt bazy danych
Aleksandra Kobusińska nr indeksu: 218366 Hurtownia Świętego Mikołaja projekt bazy danych Zaprezentowana poniżej baza jest częścią większego projektu bazy danych wykorzystywanej w krajowych oddziałach wiosek
Relacyjne bazy danych. Podstawy SQL
Relacyjne bazy danych Podstawy SQL Język SQL SQL (Structured Query Language) język umożliwiający dostęp i przetwarzanie danych w bazie danych na poziomie obiektów modelu relacyjnego tj. tabel i perspektyw.
Aspekty aktywne baz danych
Aspekty aktywne baz danych Aktywne aspekty baz danych Baza danych powinna zapewniać pewne własności i niezmienniki; Własności te powinny mogą być zapisane do bazy danych, a baza danych powinna zapewniać
Bazy danych 9. Klucze obce Transakcje
Bazy danych 9. Klucze obce Transakcje P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2007/08 Dygresja: Metody przechowywania tabel w MySQL Tabele w MySQL moga być przechowywane na kilka
Plan bazy: Kod zakładający bazę danych: DROP TABLE noclegi CASCADE; CREATE TABLE noclegi( id_noclegu SERIAL NOT NULL,
Mój projekt przedstawia bazę danych noclegów składającą się z 10 tabel. W projekcie wykorzystuje program LibreOffice Base do połączenia psql z graficznym interfejsem ( kilka formularzy przedstawiających
Wykład 5 funkcje i procedury pamiętane widoki (perspektywy) wyzwalacze
Wykład 5 funkcje i procedury pamiętane widoki (perspektywy) wyzwalacze 1 Funkcje i procedury pamiętane Następujące polecenie tworzy zestawienie zawierające informację o tym ilu jest na naszej hipotetycznej
Wprowadzenie do BD Operacje na bazie i tabelach Co poza zapytaniami? Algebra relacji. Bazy Danych i Systemy informacyjne Wykład 2.
Bazy Danych i Systemy informacyjne Wykład 2 Piotr Syga 16.10.2017 Dodawanie, usuwanie i zmienianie rekordów Wstawianie rekordu wstawianie do tabeli INSERT INTO A VALUES ( fioletowy, okrągły, słodko-kwaśny
E.14 Bazy Danych cz. 17 SQL Widoki
Wprowadzenie Tworzenie widoków Złączenie zewnętrzne w definicji widoków Uporządkowywanie danych poprzez widoki Modyfikowanie danych poprzez widoki Ograniczenie zakresu modyfikowania danych poprzez widoki
strukturalny język zapytań używany do tworzenia i modyfikowania baz danych oraz do umieszczania i pobierania danych z baz danych
SQL SQL (ang. Structured Query Language): strukturalny język zapytań używany do tworzenia strukturalny język zapytań używany do tworzenia i modyfikowania baz danych oraz do umieszczania i pobierania danych
Kurs. Podstawy MySQL
Kurs Podstawy MySQL Krótkie info. Autorem kursu jest Piotr Jędrusik. Kurs jest własnością serwisu MySQL FAQ www.mysqlfaq.prv.pl, email: mysqlfaq@twister.pl. 1. Tworzymy bazę. Stworzymy pierwszą bazę o
Tworzenie widoku CREATE OR REPLACE VIEW [nazwa_widoku] AS SELECT [nazwy_kolumn] FROM [nazwa_tablicy];
Widoki/Perspektywy Podstawy Tworzenie widoku CREATE OR REPLACE VIEW [nazwa_widoku] AS SELECT [nazwy_kolumn] FROM [nazwa_tablicy]; Usuwanie widoku DROP VIEW [nazwa_widoku]; Przykład 1 Przykład najprostszego
Wyzwalacz - procedura wyzwalana, składowana fizycznie w bazie, uruchamiana automatycznie po nastąpieniu określonego w definicji zdarzenia
Wyzwalacz - procedura wyzwalana, składowana fizycznie w bazie, uruchamiana automatycznie po nastąpieniu określonego w definicji zdarzenia Składowe wyzwalacza ( ECA ): określenie zdarzenia ( Event ) określenie
Połączenie z bazą danych : mysql h u root -p Enter password: *******
Połączenie z bazą danych : mysql h 127.0.0.1 -u root -p Enter password: ******* wyświetlenie istniejących baz danych: show databases; Database mysql test Uwaga ważny średnik na końcu każdej linii. Tworzenie
Blaski i cienie wyzwalaczy w relacyjnych bazach danych. Mgr inż. Andrzej Ptasznik
Blaski i cienie wyzwalaczy w relacyjnych bazach danych. Mgr inż. Andrzej Ptasznik Technologia Przykłady praktycznych zastosowań wyzwalaczy będą omawiane na bazie systemu MS SQL Server 2005 Wprowadzenie
Relacyjne bazy danych. Podstawy SQL
Relacyjne bazy danych Podstawy SQL Język SQL SQL (Structured Query Language) język umoŝliwiający dostęp i przetwarzanie danych w bazie danych na poziomie obiektów modelu relacyjnego tj. tabel i perspektyw.
BAZA DANYCH SIECI HOTELI
Paulina Gogół s241906 BAZA DANYCH SIECI HOTELI Baza jest częścią systemu zarządzającego pewną siecią hoteli. Składa się z tabeli powiązanych ze sobą różnymi relacjami. Służy ona lepszemu zorganizowaniu
Wykład 05 Bazy danych
Wykład 05 Bazy danych Tabela składa się z: Kolumn Wierszy Wartości Nazwa Wartości Opis INT [UNSIGNED] -2^31..2^31-1 lub 0..2^32-1 Zwykłe liczby całkowite VARCHAR(n) n = długość [1-255] Łańcuch znaków o
Wyzwalacze. do automatycznego generowania wartości kluczy głównych. Składnia instrukcji tworzacej wyzwalacz
Wyzwalacze Wyzwalacze są specjalnymi procedurami składowanymi, uruchamianymi automatycznie w następstwie zaistnienia określonego typu zdarzenia. Ich główne zadanie polega na wymuszaniu integralności danych
Oracle PL/SQL. Paweł Rajba. pawel@ii.uni.wroc.pl http://www.kursy24.eu/
Paweł Rajba pawel@ii.uni.wroc.pl http://www.kursy24.eu/ Zawartość modułu 6 Wprowadzenie Definiowanie wyzwalaczy DML Metadane wyzwalaczy Inne zagadnienia, tabele mutujące Wyzwalacze INSTEAD OF Wyzwalacze
Procedury wyzwalane. (c) Instytut Informatyki Politechniki Poznańskiej 1
Procedury wyzwalane procedury wyzwalane, cel stosowania, typy wyzwalaczy, wyzwalacze na poleceniach DML i DDL, wyzwalacze typu INSTEAD OF, przykłady zastosowania, zarządzanie wyzwalaczami 1 Procedury wyzwalane
SQL 4 Structured Query Lenguage
Wykład 5 SQL 4 Structured Query Lenguage Instrukcje sterowania danymi Bazy Danych - A. Dawid 2011 1 CREATE USER Tworzy nowego użytkownika Składnia CREATE USER specyfikacja użytkownika [, specyfikacja użytkownika]...
Język SQL, zajęcia nr 1
Język SQL, zajęcia nr 1 SQL - Structured Query Language Strukturalny język zapytań Login: student Hasło: stmeil14 Baza danych: st https://194.29.155.15/phpmyadmin/index.php Andrzej Grzebielec Najpopularniejsze
Administracja i programowanie pod Microsoft SQL Server 2000
Administracja i programowanie pod Paweł Rajba pawel@ii.uni.wroc.pl http://www.kursy24.eu/ Zawartość modułu 6 Wyzwalacze Wprowadzenie Tworzenie wyzwalacza Wyzwalacze typu,,po'' Wyzwalacze typu,,zamiast''
Wykład 5. SQL praca z tabelami 2
Wykład 5 SQL praca z tabelami 2 Wypełnianie tabel danymi Tabele można wypełniać poprzez standardową instrukcję INSERT INTO: INSERT [INTO] nazwa_tabeli [(kolumna1, kolumna2,, kolumnan)] VALUES (wartosc1,
DECLARE VARIABLE zmienna1 typ danych; BEGIN
Procedury zapamiętane w Interbase - samodzielne programy napisane w specjalnym języku (właściwym dla serwera baz danych Interbase), który umożliwia tworzenie zapytań, pętli, instrukcji warunkowych itp.;
UPDATE Studenci SET Rok = Rok + 1 WHERE Rodzaj_studiow =' INŻ_ST'; UPDATE Studenci SET Rok = Rok 1 WHERE Nr_albumu IN ( '111345','100678');
polecenie UPDATE służy do aktualizacji zawartości wierszy tabel lub perspektyw składnia: UPDATE { } SET { { = DEFAULT NULL}, {
Projektowanie systemów baz danych
Projektowanie systemów baz danych Seweryn Dobrzelewski 4. Projektowanie DBMS 1 SQL SQL (ang. Structured Query Language) Język SQL jest strukturalnym językiem zapewniającym możliwość wydawania poleceń do
Bazy danych. Wykład IV SQL - wprowadzenie. Copyrights by Arkadiusz Rzucidło 1
Bazy danych Wykład IV SQL - wprowadzenie Copyrights by Arkadiusz Rzucidło 1 Czym jest SQL Język zapytań deklaratywny dostęp do danych Składnia łatwa i naturalna Standardowe narzędzie dostępu do wielu różnych
Przykład 3 Zdefiniuj w bazie danych hurtownia_nazwisko przykładową funkcję użytkownika fn_rok;
Temat: Funkcje, procedury i wyzwalacze. Oprócz tabel i widoków w bazach danych możemy tworzyć własne funkcje, procedury i specjalny typ procedur, które będą automatycznie wywoływanie przez MySQL w memencie
Autor: Joanna Karwowska
Autor: Joanna Karwowska Klucz podstawowy PRIMARY KEY Klucz kandydujący UNIQUE Klucz alternatywny - klucze kandydujące, które nie zostały wybrane na klucz podstawowy Klucz obcy - REFERENCES Tworząc tabelę,
Kowalski Marcin 156439 Wrocław, dn. 3.06.2009 Jaśkiewicz Kamil 148592. Bazy Danych 1 Podstawy Projekt Temat: Baza danych do zarządzania projektami
Kowalski Marcin 156439 Wrocław, dn. 3.06.2009 Jaśkiewicz Kamil 148592 Bazy Danych 1 Podstawy Projekt Temat: Baza danych do zarządzania projektami Spis treści Założenia Projektowe...1 Schemat Bazy Danych...1
Wykład IV Modelowanie danych, projektowanie systemu informatycznego Modelowanie konceptualne implementacyjne Modelowanie pojęciowe na encjach
Modelowanie danych, projektowanie systemu informatycznego Modelowanie odwzorowanie rzeczywistych obiektów świata rzeczywistego w systemie informatycznym. Modele - konceptualne reprezentacja obiektów w
Bazy danych 8. Procedury składowane i kursory. P. F. Góra
Bazy danych 8. Procedury składowane i kursory P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2017 Procedury składowane (stored procedures) Procedury składowane stanowia część schematu bazy danych. Stosuje
I. Język manipulowania danymi - DML (Data Manipulation Language). Polecenia INSERT, UPDATE, DELETE
Wykład 9 Implementacja języka SQL w systemach baz danych Oracle manipulowanie danymi (DML), tworzenie, modyfikowanie i usuwanie obiektów bazy danych: tabel i perspektyw, więzów integralności, komentarzy
Bazy danych 6. SQL funkcje daty i czasu, zmienne tymczasowe, aliasy
Bazy danych 6. SQL funkcje daty i czasu, zmienne tymczasowe, aliasy P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2007/08 MySQL i programowanie wsadowe C:\wyklady\bazy> mysql < nazwa pliku
Instrukcja podwaja zarobki osób, których imiona zaczynają się P i dalsze litery alfabetu zakładamy, że takich osbób jest kilkanaście.
Rodzaje triggerów Triggery DML na tabelach INSERT, UPDATE, DELETE Triggery na widokach INSTEAD OF Triggery DDL CREATE, ALTER, DROP Triggery na bazie danych SERVERERROR, LOGON, LOGOFF, STARTUP, SHUTDOWN
Programowanie MSQL. show databases; - pokazanie jakie bazy danych są dostępne na koncie
Programowanie MSQL show databases; - pokazanie jakie bazy danych są dostępne na koncie show databases; - wyświetlenie wszystkich baz danych na serwerze create database nazwa; - za nazwa wstawiamy wybraną
Cele. Definiowanie wyzwalaczy
WYZWALACZE Definiowanie wyzwalaczy Cele Wyjaśnić cel istnienia wyzwalaczy Przedyskutować zalety wyzwalaczy Wymienić i opisać cztery typy wyzwalaczy wspieranych przez Adaptive Server Anywhere Opisać dwa
Używany kiedy pełna treść instrukcji SQL jest nieznana przed uruchomieniem programu.
Plan wykładu Spis treści 1 Dynamiczny SQL 1 2 Wyzwalacze 2 3 Podsumowanie 9 4 Źródła 9 1 Dynamiczny SQL Dynamiczny SQL Dynamiczny SQL - technika programowania umożliwiająca generowanie instrukcji SQL dynamicznie
Bazy danych. dr inż. Arkadiusz Mirakowski
Bazy danych dr inż. Arkadiusz Mirakowski Początek pracy z Transact SQL (T-SQL) 153.19.7.13,1401 jkowalski nr indeksu 2 Perspektywa - tabela tymczasowa - grupowanie Perspektywa (widok) Perspektywa (widok)
Przykładowa baza danych BIBLIOTEKA
Przykładowa baza danych BIBLIOTEKA 1. Opis problemu W ramach zajęć zostanie przedstawiony przykład prezentujący prosty system biblioteczny. System zawiera informację o czytelnikach oraz książkach dostępnych
Tworzenie tabel. Bazy danych - laboratorium, Hanna Kleban 1
Tworzenie tabel Tabela podstawowa struktura, na której zbudowana jest relacyjna baza danych. Jest to zbiór kolumn (atrybutów) o ustalonych właściwościach, w których przechowuje się dane. Dane te są reprezentowane
Bazy danych 4. Przykłady SQL podstawy
Bazy danych 4. Przykłady SQL podstawy P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2011/12 Przykład I Przedsiębiorca tworzy bazę danych pracowników na potrzeby wypłacania im wynagrodzeń i przekazywania
3 Przygotowali: mgr inż. Barbara Łukawska, mgr inż. Maciej Lasota
Laboratorium nr 3 1 Bazy Danych Instrukcja laboratoryjna Temat: Wprowadzenie do języka SQL, tworzenie, modyfikacja, wypełnianie tabel 3 Przygotowali: mgr inż. Barbara Łukawska, mgr inż. Maciej Lasota 1)
Bazy danych 7. Klucze obce Transakcje. P. F. Góra
Bazy danych 7. Klucze obce Transakcje P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2011 Dygresja: Metody przechowywania tabel w MySQL Tabele w MySQL moga być przechowywane na kilka sposobów. Sposób
Aby uruchomić program klienta i połączyć się z serwerem, należy komendę:
Bazy danych. Komunikacja z serwerem Aby połączyć się z serwerem i móc wykonywać czynności związane z obsługą baz, potrzebny jest program klienta. Razem z serwerem MySQL dostępny jest działający w wierszu
Grupowanie i funkcje agregujące
Grupowanie i funkcje agregujące Zadanie 1. Stwórz odpowiednią tabelę Test_agr i wprowadź odpowiednie rekordy tak, aby wynik zapytania SELECT AVG(kol) avg_all, AVG(DISTINCT kol) avg_dist, COUNT(*) count_gw,
Język SQL, zajęcia nr 2
Język SQL, zajęcia nr 2 SQL - Structured Query Language Strukturalny język zapytań Login: student Hasło: stmeil14 Baza danych: st https://194.29.155.15/phpmyadmin/index.php Andrzej Grzebielec Funkcja agregująca
Bazy danych wykład szósty Więzy i wyzwalacze. Konrad Zdanowski ( Uniwersytet Kardynała Stefana Bazy danych Wyszyńskiego, wykładwarszawa)
Bazy danych wykład szósty Więzy i wyzwalacze Konrad Zdanowski Uniwersytet Kardynała Stefana Wyszyńskiego, Warszawa szósty Więzy i wyzwalacze 1 / 35 Wstęp Wiemy jak nakładać pewne ograniczenia (więzy) w
Bazy Danych - Instrukcja do Ćwiczenia laboratoryjnego nr 8
Bazy Danych - Instrukcja do Ćwiczenia laboratoryjnego nr 8 Bazowy skrypt PHP do ćwiczeń z bazą MySQL: Utwórz skrypt o nazwie cw7.php zawierający następującą treść (uzupełniając go o właściwą nazwę uŝytkownika
Zarzadzanie transakcjami. Transakcje
Transakcje Transakcja: ciąg zawierający jedno lub wiele poleceń SQL, zgrupowanych razem jako jedna logiczna jednostka działań, której nie można podzielić. Logiczna jednostka działań to zbiór logicznych
77. Modelowanie bazy danych rodzaje połączeń relacyjnych, pojęcie klucza obcego.
77. Modelowanie bazy danych rodzaje połączeń relacyjnych, pojęcie klucza obcego. Przy modelowaniu bazy danych możemy wyróżnić następujące typy połączeń relacyjnych: jeden do wielu, jeden do jednego, wiele
Bazy danych 12. SQL Wyszukiwanie pełnotekstowe
Bazy danych 12. SQL Wyszukiwanie pełnotekstowe P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2007/08 Wyszukiwanie pełnotekstowe Wyszukiwanie pełnotekstowe służy do wyszukiwania podanych
LAB2. Dalsze ćwiczenia z podstaw języka SQL (CREATE, ALTER, DROP, INSERT, UPDATE, DELETE, SELECT)
LAB2. Dalsze ćwiczenia z podstaw języka SQL (CREATE, ALTER, DROP, INSERT, UPDATE, DELETE, SELECT) 1. Uwagi wstępne W tym ćwiczeniu przećwiczymy raz jeszcze najważniejsze elementy języka SQL (ang. Structured
Laboratorium nr 4. Temat: SQL część II. Polecenia DML
Laboratorium nr 4 Temat: SQL część II Polecenia DML DML DML (Data Manipulation Language) słuŝy do wykonywania operacji na danych do ich umieszczania w bazie, kasowania, przeglądania, zmiany. NajwaŜniejsze
Pawel@Kasprowski.pl Bazy danych. Bazy danych. Podstawy języka SQL. Dr inż. Paweł Kasprowski. pawel@kasprowski.pl
Bazy danych Podstawy języka SQL Dr inż. Paweł Kasprowski pawel@kasprowski.pl Plan wykładu Relacyjne bazy danych Język SQL Zapytania SQL (polecenie select) Bezpieczeństwo danych Integralność danych Współbieżność
Język SQL. Rozdział 10. Perspektywy Stosowanie perspektyw, tworzenie perspektyw prostych i złożonych, perspektywy modyfikowalne i niemodyfikowalne.
Język SQL. Rozdział 10. Perspektywy Stosowanie perspektyw, tworzenie perspektyw prostych i złożonych, perspektywy modyfikowalne i niemodyfikowalne. 1 Perspektywa Perspektywa (ang. view) jest strukturą
T-SQL dla każdego / Alison Balter. Gliwice, cop Spis treści. O autorce 11. Dedykacja 12. Podziękowania 12. Wstęp 15
T-SQL dla każdego / Alison Balter. Gliwice, cop. 2016 Spis treści O autorce 11 Dedykacja 12 Podziękowania 12 Wstęp 15 Godzina 1. Bazy danych podstawowe informacje 17 Czym jest baza danych? 17 Czym jest
KOLEKCJE - to typy masowe,zawierające pewną liczbę jednorodnych elementów
KOLEKCJE - to typy masowe,zawierające pewną liczbę jednorodnych elementów SQL3 wprowadza następujące kolekcje: zbiory ( SETS ) - zestaw elementów bez powtórzeń, kolejność nieistotna listy ( LISTS ) - zestaw
Wykład 6. SQL praca z tabelami 3
Wykład 6 SQL praca z tabelami 3 Łączenie wyników zapytań Język SQL zawiera mechanizmy pozwalające na łączenie wyników kilku pytań. Pozwalają na to instrukcje UNION, INTERSECT, EXCEPT o postaci: zapytanie1
Bazy Danych. SQL Podstawy języka III: powtórzenie. Krzysztof Regulski WIMiIP, KISiM, B5, pok. 408
Bazy Danych SQL Podstawy języka III: powtórzenie Krzysztof Regulski WIMiIP, KISiM, regulski@agh.edu.pl B5, pok. 408 Modyfikacja schematu relacji Utwórz tabelę wg schematu: CREATE TABLE ODDZIAL ( numer_oddzialu
Programowanie w SQL procedury i funkcje. UWAGA: Proszę nie zapominać o prefiksowaniu nazw obiektów ciągiem [OLIMP\{nr indeksu}] Funkcje użytkownika
Programowanie w SQL procedury i funkcje UWAGA: Proszę nie zapominać o prefiksowaniu nazw obiektów ciągiem [OLIMP\{nr indeksu}] Funkcje użytkownika 1. Funkcje o wartościach skalarnych ang. scalar valued
Instytut Mechaniki i Inżynierii Obliczeniowej Wydział Mechaniczny Technologiczny Politechnika Śląska
Instytut Mechaniki i Inżynierii Obliczeniowej www.imio.polsl.pl fb.com/imiopolsl @imiopolsl Wydział Mechaniczny Technologiczny Politechnika Śląska Laboratorium 1 Wprowadzenie, podstawowe informacje o obsłudze
Podstawy języka SQL. SQL Structured Query Languagestrukturalny
Podstawy języka SQL SQL Structured Query Languagestrukturalny język zapytań DDL Język definicji danych (np. tworzenie tabel) DML Język manipulacji danych (np. tworzenie zapytań) DCL Język kontroli danych
PODSTAWY BAZ DANYCH 13. PL/SQL
PODSTAWY BAZ DANYCH 13. PL/SQL 1 Wprowadzenie do języka PL/SQL Język PL/SQL - rozszerzenie SQL o elementy programowania proceduralnego. Możliwość wykorzystywania: zmiennych i stałych, instrukcji sterujących
1 Zaznacz poprawne stwierdzenia dotyczące grup plików (filegroup) możemy określić do której grupy plików trafi
1 Zaznacz poprawne stwierdzenia dotyczące grup plików (filegroup) Tworząc tabelę nie możemy określić, do którego pliku trafi, lecz możemy określić do której grupy plików trafi Zawsze istnieje grupa zawierająca
Bazy danych i usługi sieciowe
Bazy danych i usługi sieciowe SQL dokończenie Paweł Daniluk Wydział Fizyki Jesień 2016 P. Daniluk (Wydział Fizyki) BDiUS w. V Jesień 2016 1 / 39 Data Manipulation Language Zapytania klauzula SELECT Wstawianie
1. Wyzwalacze BD (ang. triggers)
1. Wyzwalacze BD (ang. triggers) Wyzwalacz bazy danych jest procedurą składowaną w bazie powiązaną z jedną konkretną tablicą. Z pojedynczą tablicą może być związane wiele wyzwalaczy, natomiast pojedynczy
Bazy danych 5. SQL- złaczenia, podzapytania i grupowanie
Bazy danych 5. SQL- złaczenia, podzapytania i grupowanie P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2017/18 Złaczenia teoriomnogościowe mysql> CREATE DATABASE JanMaria; Query OK, 1 row affected (0.02
Programowanie po stronie serwera w SZBD. Robert A. Kłopotek Wydział Matematyczno-Przyrodniczy. Szkoła Nauk Ścisłych, UKSW
Programowanie po stronie serwera w SZBD Robert A. Kłopotek r.klopotek@uksw.edu.pl Wydział Matematyczno-Przyrodniczy. Szkoła Nauk Ścisłych, UKSW Programowanie SZBD (DBMS) Procedury serwera Procedury składowane
ACESS- zadania z wykorzystaniem poleceń SQL
ACESS- zadania z wykorzystaniem poleceń SQL Dane są relacje o schematach: Pracownik ( (nr integer, nazwisko text(12), etat text(10), szef integer, pracuje_od date, placa_pod Currency, placa_dod Currency,
Systemowe aspekty baz
Systemowe aspekty baz danych Deklaracja zmiennej Zmienne mogą być wejściowe i wyjściowe Zmienne w T-SQL można deklarować za pomocą @: declare @nazwisko varchar(20) Zapytanie z użyciem zmiennej: select
Literatura: SQL Ćwiczenia praktyczne Autor: Marcin Lis Wydawnictwo: Helion. Autor: Joanna Karwowska
Literatura: SQL Ćwiczenia praktyczne Autor: Marcin Lis Wydawnictwo: Helion Autor: Joanna Karwowska SQL zapewnia obsługę: zapytań - wyszukiwanie danych w bazie, operowania danymi - wstawianie, modyfikowanie
Widok Connections po utworzeniu połączenia. Obszar roboczy
Środowisko pracy 1. Baza danych: Oracle 12c - Serwer ELARA - Konta studenckie, dostęp także spoza uczelni - Konfiguracja: https://e.piotrowska.po.opole.pl/index.php?option=conf 2. Środowisko: SQL Developer
SQL język zapytań (query language) cz.1
SQL język zapytań (query language) cz.1 Zapytanie SELECT - podstawy (3) SELECT A 1,A 2,...,A k (1) FROM R 1,R 2,,R n -- lista wyboru (atrybutów) -- relacje (lista FROM) (2) WHERE F -- warunek wyboru (selekcji)
Modelowanie wymiarów
Wymiar Modelowanie wymiarów struktura umożliwiająca grupowanie danych z tabeli faktów implementowana jako obiekt bazy danych DIMENSION wykorzystanie DIMENSION zaawansowane przepisywanie zapytań (ang. query