Bazy danych 8. Procedury składowane i kursory. P. F. Góra
|
|
- Grażyna Amelia Matusiak
- 6 lat temu
- Przeglądów:
Transkrypt
1 Bazy danych 8. Procedury składowane i kursory P. F. Góra
2 Procedury składowane (stored procedures) Procedury składowane stanowia część schematu bazy danych. Stosuje się je do wykonowania powtarzajacych się, logicznie takich samych operacji na (bazie) danych, nie wymagajacych ingerencji ze strony użytkownika. Zalety używania procedur składowanych: Różne aplikacje korzystajace z tej samej bazy danych korzystaja z tej samej procedury mniejsze ryzyko popełnienia błędu. Zwiększone bezpieczeństwo: Nie udostępniamy użytkownikom bezpośrednio tabel (hacker mógłby dobrać się do tabeli z hasłami!), zezwalamy tylko na wykonywanie predefiniowanych procedur. Mniejsze koszty uruchomienia i konserwacji. Automatyzacja obsługi błędów Zmniejszenie kosztu przesyłu danych. Copyright c P. F. Góra 8 2
3 Najprostszy przykład mysql> DELIMITER// Przed zdefiniowaniem procedury należy redefiniować średnik, żeby średniki w ciele procedury nie były interpretowane jako koniec zapytania definiujacego procedurę. mysql> DELIMITER // mysql> CREATE PROCEDURE proc01 () -> /* To jest komentarz */ -> SELECT * FROM arabic; /* "arabic" jest nazwą tabeli */ -> // Query OK, 0 rows affected (0.01 sec) mysql> DELIMITER ; Copyright c P. F. Góra 8 3
4 Wywołanie procedury instrukcja CALL mysql> CALL proc01 (); i b x jeden X 2 dwa X 4 cztery X 3 trzy X 5 pięć X 6 sześć X 7 siedem X 8 osiem X 9 dziewięć X 10 dziesięć X 12 dwanaście X rows in set (0.00 sec) Query OK, 0 rows affected (0.01 sec) Copyright c P. F. Góra 8 4
5 Klauzule definicyjne mysql> DELIMITER // mysql> CREATE PROCEDURE proc02() -> LANGUAGE SQL -> NOT DETERMINISTIC -> SQL SECURITY INVOKER -> COMMENT Przykład -> SELECT RAND(); -> // Query OK, 0 rows affected (1.14 sec) mysql> DELIMITER ; mysql> CALL proc02 (); RAND() row in set (0.02 sec) Query OK, 0 rows affected (0.02 sec) LANGUAGE SQL wymagane ze względu na kompatybilność NOT DETERMINISTIC bo przy takich samych parametrach może dać różne wyniki DETERMINISTIC jeśli parametry wywołania jednoznacznie determinuja wynik SQL SECURITY INVOKER przy wywołaniu sprawdzaj przywileje wywołujacego SQL SECURITY DEFINER przy wywołaniu sprawdzaj przywileje użytkownika, który stworzył procedurę Copyright c P. F. Góra 8 5
6 Instrukcje złożone. Parametry wywołania. mysql> CREATE PROCEDURE proc03 (IN i INT) -> LANGUAGE SQL -> DETERMINISTIC -> BEGIN -> SELECT i + 2; -> SELECT i - 4; -> END; // Query OK, 0 rows affected (1.71 sec) mysql> CALL proc03 (2)// i row in set (0.10 sec) i row in set (0.10 sec) Query OK, 0 rows affected (0.10 sec) Copyright c P. F. Góra 8 6
7 mysql> CREATE PROCEDURE proc04 (INOUT j FLOAT) -> LANGUAGE SQL -> DETERMINISTIC -> BEGIN -> DECLARE z FLOAT; /* zmienna lokalna */ -> SET z = SIN(j); -> SELECT z AS zet ; -> SET j = j*z; -> END; // Query OK, 0 rows affected (0.00 sec) Zmienne lokalne maja zakres ograniczoney do swojego bloku BEGIN END. Copyright c P. F. Góra 8 7
8 mysql> = 2.0// Query OK, 0 rows affected (0.00 sec) mysql> CALL proc04 (@x) // zet row in set (1.12 sec) Query OK, 0 rows affected (1.13 sec) mysql> // row in set (0.00 sec) Copyright c P. F. Góra 8 8
9 Procedury moga uzyskać dostęp do tabel mysql> CREATE PROCEDURE proc05 (IN z CHAR(1)) -> UPDATE arabic SET x=z WHERE MOD(i,2)=0 LIMIT 4;// Query OK, 0 rows affected (1.12 sec) mysql> CALL proc05 ( P ) // Query OK, 4 rows affected (0.08 sec) mysql> SELECT * FROM arabic // i b x jeden X 2 dwa P 4 cztery P 3 trzy X 5 pięć X 6 sześć P 7 siedem X 8 osiem P 9 dziewięć X 10 dziesięć X 12 dwanaście X rows in set (0.00 sec) Copyright c P. F. Góra 8 9
10 Czego procedurom nie wolno robić? Procedury nie moga zmieniać innych procedur. W ciele procedury w MySQL nielegalne sa instrukcje CREATE ALTER DROP PROCEDURE, CREATE ALTER DROP FUNCTION, CREATE ALTER DROP TRIGGER. W MySQL wewnatrz procedury nielegalna jest instrukcja USE, można jednak odwoływać się do tabel innej bazy danych niż baza bieżaca (oczywiście o ile mamy do tego uprawnienia). Procedury moga natomiast tworzyć, usuwać i modyfikować definicje tabel, widoków i baz danych. Copyright c P. F. Góra 8 10
11 Zakres zmiennych mysql> CREATE PROCEDURE proc06 () -> BEGIN -> DECLARE napis CHAR(4) DEFAULT zewn ; -> BEGIN -> DECLARE napis CHAR(4) DEFAULT wewn ; -> SELECT napis; -> END; -> SELECT napis; -> SET napis = pqrs ; -> SELECT napis; -> END;// Query OK, 0 rows affected (0.62 sec) Copyright c P. F. Góra 8 11
12 mysql> CALL proc06 () // napis wewn 1 row in set (0.00 sec) napis zewn 1 row in set (0.00 sec) napis pqrs 1 row in set (0.00 sec) Query OK, 0 rows affected (0.16 sec) Copyright c P. F. Góra 8 12
13 Instrukcja warunkowa mysql> CREATE PROCEDURE proc07 (IN j INT) -> BEGIN -> DECLARE m INT; -> SET m = (SELECT MAX(i) FROM arabic); -> IF j > m THEN -> INSERT INTO arabic (i,b) VALUES (j, tekst ); -> ELSE -> UPDATE arabic SET i = i + m WHERE i = j; -> END IF; -> END;// Query OK, 0 rows affected (0.00 sec) Copyright c P. F. Góra 8 13
14 mysql> CALL proc07 (6) // Query OK, 1 row affected (1.75 sec) mysql> SELECT * FROM arabic // i b x jeden X 2 dwa P 4 cztery P 3 trzy X 5 pięć X 18 sześć P 7 siedem X 8 osiem P 9 dziewięć X 10 dziesięć X 12 dwanaście X rows in set (0.02 sec) mysql> CALL proc07 (19) // Query OK, 1 row affected (0.13 sec) mysql> SELECT * FROM arabic // i b x jeden X 2 dwa P 4 cztery P 3 trzy X 5 pięć X 18 sześć P 7 siedem X 8 osiem P 9 dziewięć X 10 dziesięć X 12 dwanaście X 19 tekst X rows in set (0.00 sec) Copyright c P. F. Góra 8 14
15 Instrukcja CASE mysql> CREATE PROCEDURE proc08 (IN j INT) -> CASE j -> WHEN 0 THEN SELECT j AS wynik ; -> WHEN 1 THEN SELECT 5*j AS wynik ; -> ELSE SELECT 10*j AS wynik ; -> END CASE; // Query OK, 0 rows affected (0.00 sec) mysql> CALL proc08 (0) // wynik 0 1 row in set (0.00 sec) Query OK, 0 rows affected (0.00 sec) mysql> CALL proc08 (2) // wynik 20 1 row in set (0.00 sec) Query OK, 0 rows affected (0.01 sec) Copyright c P. F. Góra 8 15
16 Pętla WHILE mysql> CREATE PROCEDURE proc09 () -> BEGIN -> DECLARE v INT; -> SET v = 1; -> WHILE v < 3 DO -> SELECT b FROM arabic -> WHERE i = v; -> SET v = v + 1; -> END WHILE; -> END; // Query OK, 0 rows affected (1.27 sec) mysql> CALL proc09 () // b jeden 1 row in set (0.45 sec) b dwa row in set (0.47 sec) Query OK, 0 rows affected (0.47 sec) Copyright c P. F. Góra 8 16
17 Pętla REPEAT mysql> CREATE PROCEDURE proc10 (OUT s INT) -> BEGIN -> DECLARE j INT DEFAULT 0; -> SET s = 1; -> REPEAT -> SET j = j + 1; -> SET s = s * j; -> UNTIL j > 5 -> END REPEAT; -> END; // Query OK, 0 rows affected (0.97 sec) mysql> CALL proc10(@s) // Query OK, 0 rows affected (0.08 sec) mysql> // row in set (0.00 sec) Copyright c P. F. Góra 8 17
18 Pętla LOOP, instrukcja LEAVE i etykiety mysql> CREATE PROCEDURE proc11 (IN k INT) -> BEGIN -> DECLARE s, v INT DEFAULT 1; -> etykieta: LOOP -> SET s = s*v; -> SET v = v+1; -> IF v > k THEN LEAVE etykieta; END IF; -> END LOOP; -> SELECT k, s; -> END; // Query OK, 0 rows affected (0.94 sec) mysql> CALL proc11 (6) // k s row in set (0.00 sec) Query OK, 0 rows affected (0.00 sec) Etykiety można stawiać przed BEGIN, WHILE, REPEAT i LOOP. Copyright c P. F. Góra 8 18
19 Instrukcja ITERATE ITERATE zignoruj resztę ciała pętli i przejdź do następnej iteracji. mysql> CREATE PROCEDURE proc12 () -> BEGIN -> DECLARE j INT DEFAULT 1; -> ett: REPEAT -> SET j = j + 1; -> IF j = 4 THEN ITERATE ett; END IF; -> SELECT i, b FROM arabic WHERE i=j; -> UNTIL j = 6 -> END REPEAT ett; -> END; // Query OK, 0 rows affected (0.00 sec) Copyright c P. F. Góra 8 19
20 mysql> CALL proc12 () // i b dwa row in set (0.00 sec) i b trzy row in set (0.00 sec) i b pięć row in set (0.00 sec) Empty set (0.00 sec) Query OK, 0 rows affected (0.00 sec) Copyright c P. F. Góra 8 20
21 Obsługa błędów (Error handling) Naturalnym zastosowanie procedur składowanych jest obsługa błędów, jakie moga pojawić się przy pracy z baza danych, na przykład na skutek naruszenia więzów. Rozpatrzmy przykład: mysql> CREATE TABLE tabela -> (K SMALLINT UNSIGNED NOT NULL PRIMARY KEY, -> W INT UNSIGNED); Query OK, 0 rows affected (1.14 sec) mysql> INSERT INTO tabela VALUES (1,10); Query OK, 1 row affected (0.12 sec) mysql> INSERT INTO tabela VALUES (2,-1); ERROR 1264 (22003): Out of range value adjusted for column W at row 1 mysql> INSERT INTO tabela VALUES (1,5); ERROR 1062 (23000): Duplicate entry 1 for key 1 Pojawienie się błędów przy nie-interaktywnym wprowadzaniu danych może spowodować problemy, których chcemy uniknać. Zarazem chcemy wiedzieć jakie błędy się pojawiły. Copyright c P. F. Góra 8 21
22 mysql> CREATE TABLE log_bledow (B VARCHAR(80)) CHARSET cp1250; Query OK, 0 rows affected (1.31 sec) mysql> DELIMITER // mysql> CREATE PROCEDURE safeinsert (IN k INT, IN w INT) -> BEGIN -> /* Pierwszy handler */ -> DECLARE EXIT HANDLER FOR > BEGIN -> SET CHARSET cp1250; -> INSERT INTO log_bledow VALUES -> (CONCAT( Godzina:,current_time, powtórzony klucz,k)); -> END; -> /* Drugi handler */ -> DECLARE EXIT HANDLER FOR > BEGIN -> SET CHARSET cp1250; -> INSERT INTO log_bledow VALUES -> (CONCAT( Godzina:,current_time, ujemna wartość,w)); -> END; -> /* Ciało procedury - wstawianie */ -> INSERT INTO tabela VALUES (k, w); -> END; // Query OK, 0 rows affected (0.49 sec) Copyright c P. F. Góra 8 22
23 mysql> CALL safeinsert (1,5); Query OK, 1 row affected (0.09 sec) mysql> CALL safeinsert (1,6); Query OK, 1 row affected (0.11 sec) mysql> CALL safeinsert (2,7); Query OK, 1 row affected (0.04 sec) mysql> CALL safeinsert (3,-1); Query OK, 1 row affected (0.03 sec) mysql> SELECT * FROM tabela; K W rows in set (0.00 sec) mysql> SELECT * FROM log_bledow; B Godzina: 09:44:06 powtórzony klucz 1 Godzina: 09:44:36 ujemna wartość rows in set (0.00 sec) Copyright c P. F. Góra 8 23
24 Polecenia PREPARE i EXECUTE Przypuśmy, że mamy kilka tabel o takiej samej strukturze, na przykład mysql> CREATE TABLE Kowalski -> (Data DATE NOT NULL, -> Miasto VARCHAR(16) NOT NULL, -> Kwota DECIMAL(8,2) UNSIGNED NOT NULL, -> PRIMARY KEY(Data, Miasto)); Query OK, 0 rows affected (1.10 sec) mysql> CREATE TABLE Nowak LIKE Kowalski; Query OK, 0 rows affected (0.16 sec) mysql> INSERT INTO Nowak VALUES (...); mysql> INSERT INTO Kowalski VALUES (...); Copyright c P. F. Góra 8 24
25 Tabele Kowalski i Nowak maja taka sama strukturę, a więc, logicznie rzecz biorac, można ich użyć w takim samym zapytaniu w zapytaniu różniacym się tylko nazwa tabeli. Po stronie aplikacji zapytanie takie jest bardzo łatwo zbudować jako odpowiedni łańcuch, a następnie przesłać je do serwera SQL. Jednak traci się w ten sposób możliwość korzystania z procedur składowanych, a zatem wszystkie korzyści wynikajace z używania takich procedur. Pytanie: Czy w SQL nazwy tabel moga być parametrami procedur składowanych? Tak należy jednak wykorzystać polecenia PREPARE i EXECUTE. Copyright c P. F. Góra 8 25
26 Procedura majaca nazwę tabeli jako argument CREATE PROCEDURE monthsales (IN nazwisko VARCHAR(16), IN miesiac TINYINT UNSIGNED) LANGUAGE SQL NOT DETERMINISTIC SQL SECURITY DEFINER BEGIN DECLARE EXIT HANDLER FOR 1146 BEGIN SELECT nazwisko AS "Nazwisko", "Nie ma takiej tabeli" AS "Brak tabeli"; END; /* tekst tworzonej komendy przechowuję _w_zmiennej_tymczasowej_! */ = CONCAT( SELECT ",nazwisko, " AS Nazwisko, SUM(KWOTA) FROM,nazwisko, WHERE MONTH(Data)=,miesiac, ; ); AS Wykonam następującą komendę ; /* utworzenie zapytania */ /* "komenda" jest >>handlerem<< utworzonego zapytania */ PREPARE komenda /* wykonanie utworzonego zapytania */ EXECUTE komenda; /* usunięcie >>handlera<< */ DEALLOCATE PREPARE komenda; END; Copyright c P. F. Góra 8 26
27 mysql> CALL monthsales ( Kowalski,5); Wykonam następującą komendę SELECT "Kowalski" AS Nazwisko, SUM(KWOTA) FROM Kowalski WHERE MONTH(Data)=5; row in set (0.00 sec) Nazwisko SUM(KWOTA) Kowalski row in set (0.01 sec) Query OK, 0 rows affected (0.01 sec) Copyright c P. F. Góra 8 27
28 mysql> CALL monthsales ( Nowak, 5); Wykonam następującą komendę SELECT "Nowak" AS Nazwisko, SUM(KWOTA) FROM Nowak WHERE MONTH(Data)=5; row in set (0.00 sec) Nazwisko SUM(KWOTA) Nowak row in set (0.00 sec) Query OK, 0 rows affected (0.01 sec) Copyright c P. F. Góra 8 28
29 mysql> CALL monthsales ( XYZ,4); Wykonam następującą komendę SELECT "XYZ" AS Nazwisko, SUM(KWOTA) FROM XYZ WHERE MONTH(Data)=4; row in set (0.00 sec) Nazwisko Brak tabeli XYZ Nie ma takiej tabeli row in set (0.01 sec) Query OK, 0 rows affected (0.01 sec) Copyright c P. F. Góra 8 29
30 Funkcje składowane Ważne ograniczenie w MySQL: funkcje składowane nie maja dostępu do danych przechowywanych w bazie mysql> CREATE FUNCTION sumasinusow (n INT) -> RETURNS FLOAT -> DETERMINISTIC -> BEGIN -> DECLARE sumasinusow FLOAT DEFAULT 0; -> DECLARE i INT DEFAULT 1; -> WHILE i < n DO -> SET sumasinusow = sumasinusow + SIN(i); -> SET i = i + 1; -> END WHILE; -> RETURN sumasinusow; -> END; // Query OK, 0 rows affected (1.01 sec) Ważne: Zmienna zwracana musi być zainicjalizowana (przez DEFAULT lub SET), gdyż w przeciwnym razie funkcja zwróci NULL. Copyright c P. F. Góra 8 30
31 mysql> SELECT sumasinusow(15) // sumasinusow(15) row in set (0.43 sec) Copyright c P. F. Góra 8 31
32 Kursory SQL jest językiem deklaratywnym: Określamy co chcemy zrobić, nie zaś jak to zrobić. Kursory pozwalaja na obsługę tabel wiersz po wierszu, a więc stanowia odejście od paradygmatu deklaratywnego w stronę paradygmatu imperatywnego. Obsługa wiersz po wierszu jest typowa dla aplikacji pisanych w językach wysokiego poziomu. Dlaczego więc robi się to w SQL? Żeby zmniejszyć koszt zwiazany z przesyłaniem znacznej ilości danych. W MySQL kursory realizowane sa za pomoca procedur składowanych. Copyright c P. F. Góra 8 32
33 Co można zrobić z kursorem? Zadeklarować Otworzyć Pobrać dane, następnie zaś przejść do następnego wiersza Zamknać Kursorów warto używać tylko wtedy, gdy przesuwaja się po kolumnie indeksowanej z unikalnymi wartościami najlepiej jeśli jest kluczem głównym. Copyright c P. F. Góra 8 33
34 Przykład: Suma narastajaca poprzez kursor mysql> CREATE PROCEDURE kurs1 () -> BEGIN -> /* Najpierw deklarujemy zmienne */ -> DECLARE koniec, j SMALLINT UNSIGNED; /* zmienna koniec ma wartość NULL */ -> DECLARE suma, z FLOAT DEFAULT 0.0; -> /* Potem deklarujemy kursor */ -> /* Zapytanie SELECT może być bardzo skomplikowane */ -> DECLARE k1 CURSOR FOR SELECT I, X FROM przebieg ORDER BY I; -> /* Co zrobić gdy dojdziemy do ostatniego wiersza */ -> DECLARE CONTINUE HANDLER FOR NOT FOUND -> SET koniec = 1; -> /* Zakładamy tabelę tymczasową */ -> DROP TEMPORARY TABLE IF EXISTS RunningTotal; -> CREATE TEMPORARY TABLE RunningTotal -> (I SMALLINT UNSIGNED NOT NULL PRIMARY KEY, -> X FLOAT, SumaNarastajaca FLOAT); To nie koniec! Copyright c P. F. Góra 8 34
35 -> /* Otwieramy kursor */ -> OPEN k1; -> /* Pętla wiersz po wierszu */ -> petla: LOOP -> /* pobranie danych do kursora */ -> FETCH k1 INTO j, z; -> /* wyjdź jeśli już skończyły się wiersze */ -> IF koniec = 1 THEN -> LEAVE petla; -> END IF; -> /* oblicz i wstaw dane do tabeli tymczasowej */ -> SET suma = suma + z; -> INSERT INTO RunningTotal VALUES (j,z,suma); -> END LOOP petla; -> /* koniec pętli po wierszach */ -> END; // Copyright c P. F. Góra 8 35
36 mysql> CALL kurs1 () ; Query OK, 1 row affected (2.17 sec) mysql> SELECT * FROM RunningTotal; I X SumaNarastajaca rows in set (0.09 sec) Copyright c P. F. Góra 8 36
37 Odstępstwa od standardu SQL Kursory w MySQL (na razie?) nie sa zgodne ze standardem SQL. Najważniejsze rzeczy, których brakuje, to 1. Zgodnie ze standardem SQL, kursory moga być wrażliwe (asensitive) lub niewrażliwe (insensitive). Kursor niewrażliwy operuje na tymczasowej kopii danych jest przez to wolniejszy, ale nie raguje na zmiany wprowadzane w danych wczytanych do kursora przez inne watki. Kursor niewrażliwy jest szybszy, ale jeśli po otwarciu kursora inny watek zmieni dane wczytane do kursora, kursor może, ale nie musi, zauważyć wprowadzone zmiany. W MySQL kursory sa wrażliwe. Zgodnie ze standardem SQL, kursor niewrażliwy deklarujemy w sposób: DECLARE nazwa kursora INSENSITIVE CURSOR FOR... Copyright c P. F. Góra 8 37
38 2. Kursory w MySQL sa nieprzewijalne. Kursor po wczytaniu krotki posuwa się o jedna krotkę do przodu. Zgodnie ze standardem SQL, raz otwarty kursor może dowolnie przesuwać się po swoim zakresie. DECLARE nazwa kursora SCROLL CURSOR FOR... Wówczas legalne sa polecenia FETCH NEXT, FETCH PRIOR, FETCH LAST, FETCH FIRST, FETCH RELATIVE liczba, FETCH ABSOLUTE liczba. 3. Kursory sa tylko do odczytu za pomoca kursorów nie można zmieniać wartości otwartej przez kursor tabeli. Zgodnie ze zstandardem SQL, legalne sa polecenia typu UPDATE tabela SET... WHERE CURRENT OF CURSOR nazwa kursora; Copyright c P. F. Góra 8 38
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 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 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
Składowane procedury i funkcje
Składowane procedury i funkcje Procedury i funkcje są zestawem poleceń SQL, które są przechowywane na serwerze (tak jak dane w tablicach). Istnieją sytuacje, kiedy procedury i funkcje są szczególnie przydatne.
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]...
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.;
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 12. SQL To i owo. Algorytmy złaczeń.
Bazy danych 12. SQL To i owo. Algorytmy złaczeń. P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ semestr letni 2005/06 I. SQL uzupełnienia Pełne złaczenie zewnętrzne Złaczenia typu LEFT JOIN i RIGHT JOIN
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:
Ćwiczenia 2 IBM DB2 Data Studio
Ćwiczenia 2 IBM DB2 Data Studio Temat: Aplikacje w Data Studio 1. Projekty Tworzenie procedur, UDF, trygerów zaczynamy od utworzenia projektu File -> New -> Project wybieramy Data Development Project.
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
Zarządzanie bazą danych. Bazy Danych i Systemy informacyjne Wykład 4. Piotr Syga
Bazy Danych i Systemy informacyjne Wykład 4 Piotr Syga 26.10.2018 Procedury review Przypomnienie składni procedur Tworzenie DELIMITER $$ CREATE PROCEDURE zliczacz (OUT wynik INT) BEGIN operacje... END
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
Bloki anonimowe w PL/SQL
Język PL/SQL PL/SQL to specjalny język proceduralny stosowany w bazach danych Oracle. Język ten stanowi rozszerzenie SQL o szereg instrukcji, znanych w proceduralnych językach programowania. Umożliwia
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
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
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
Bazy danych wykład dwunasty PL/SQL, c.d. Konrad Zdanowski ( Uniwersytet Kardynała Stefana Bazy danych Wyszyńskiego, wykładwarszawa)
Bazy danych wykład dwunasty PL/SQL, c.d. Konrad Zdanowski Uniwersytet Kardynała Stefana Wyszyńskiego, Warszawa dwunasty PL/SQL, c.d. 1 / 37 SQL to za mało SQL brakuje możliwości dostępnych w językach proceduralnych.
Programowanie w SQL. definicja bloku instrukcji BEGIN...END, warunkowe wykonanie instrukcji IF...ELSE, wyrażenie CASE,
Programowanie w SQL definicja bloku instrukcji BEGIN...END, warunkowe wykonanie instrukcji IF...ELSE, wyrażenie CASE, kontynuacja działania od instrukcji za podaną etykietą GOTO etykieta, wyjście bezwarunkowe
DECLARE <nazwa_zmiennej> typ [(<rozmiar> )] [ NOT NULL ] [ { := DEFAULT } <wartość> ];
Braki w SQL obsługi zdarzeń i sytuacji wyjątkowych funkcji i procedur użytkownika definiowania złożonych ograniczeń integralnościowych Proceduralny SQL Transact- SQL używany przez Microsoft SQL Server
15. Funkcje i procedury składowane PL/SQL
15. Funkcje i procedury składowane PLSQL 15.1. SQL i PLSQL (Structured Query Language - SQL) Język zapytań strukturalnych SQL jest zbiorem poleceń, za pomocą których programy i uŝytkownicy uzyskują dostęp
Język PL/SQL Procedury i funkcje składowane
Język PL/SQL Procedury i funkcje składowane Podprogramy, procedury i funkcje składowane, typy argumentów, wywoływanie procedur i funkcji, poziomy czystości funkcji 1 Podprogramy Procedury (wykonują określone
W SQL Serwerze 2008 wprowadzono parametry tablicowe (Table Valued Parameters - TVP).
Procedury składowane c.d. Parametry tablicowe w Transact-SQL. W SQL Serwerze 2008 wprowadzono parametry tablicowe (Table Valued Parameters - TVP). Zadanie 1. Proszę napisad procedurę składowaną, która
Bazy danych 8. Widoki i wyzwalacze. P. F. Góra
Bazy danych 8. Widoki i wyzwalacze P. F. Góra http://th-www.if.uj.edu.pl/zfs/gora/ 2012 I. Widoki, AKA Perspektywy W SQL tabela, która utworzono za pomoca zapytania CREATE TABLE, nazywa się tabela podstawowa
Procedury i funkcje składowane
Procedury i funkcje składowane Zmienne podstawienia i zmienne wiązane, podprogramy, procedury składowane, typy argumentów, wywoływanie procedur, funkcje składowane, poziomy czystości funkcji, funkcje tablicowe
Systemowe aspekty baz danych
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
Język PL/SQL. Rozdział 5. Pakiety podprogramów. Dynamiczny SQL
Język PL/SQL. Rozdział 5. Pakiety podprogramów. Dynamiczny SQL Pakiety podprogramów, specyfikacja i ciało pakietu, zmienne i kursory pakietowe, pseudoinstrukcje (dyrektywy kompilatora), dynamiczny SQL.
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
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
Paweł Rajba
Paweł Rajba pawel@cs.uni.wroc.pl http://www.itcourses.eu/ Wprowadzenie Używanie kursorów Rodzaje kursorów Praca z kursorami Co to jest kursor? Cykl życia kursora utworzenie pobieranie wartości ewentualnie
Sprawdzenie poziomu izolacji transakcji (w aktualnym połączeniu):
Utwórz bazę danych Cw: CREATE DATABASE Cw Sprawdzenie poziomu izolacji transakcji (w aktualnym połączeniu): DBCC USEROPTIONS Przykład z zapisem do tabeli tymczasowej: --Jeśli istnieje tabela tymczasowa
w PL/SQL bloki nazwane to: funkcje, procedury, pakiety, wyzwalacze
w PL/SQL bloki nazwane to: funkcje, procedury, pakiety, wyzwalacze Cechy bloków nazwanych: w postaci skompilowanej trwale przechowywane na serwerze wraz z danymi wykonywane na żądanie użytkownika lub w
Kursory i wyjątki. (c) Instytut Informatyki Politechniki Poznańskiej 1
Kursory i wyjątki Kursory i praca z kursorami, kursory jawne i niejawne, otwieranie kursora, pobieranie z kursora, zamykanie kursora, wyjątki systemowe i użytkownika, zgłaszanie i obsługa wyjątków 1 Kursor
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
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
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. 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)
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 5 Kursory w SQL Serverze Wprowadzenie Modele kursorów Używanie kursorów Rodzaje kursorów Praca
Pakiety podprogramów Dynamiczny SQL
Pakiety podprogramów Dynamiczny SQL Pakiety podprogramów, specyfikacja i ciało pakietu, zmienne i kursory pakietowe, pseudoinstrukcje (dyrektywy kompilatora), dynamiczny SQL 1 Pakiety Pakiet (ang. package)
PL/SQL. Zaawansowane tematy PL/SQL
PL/SQL Zaawansowane tematy PL/SQL Cele Poznanie złożonych i referencyjnych typów danych Poznanie konstrukcji kursora Poznanie kodu składowanego Poznanie procedur i funkcji 2 Złożone typy danych RECORD
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 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
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,
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ć
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
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
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
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
Oracle PL/SQL. Paweł Rajba.
Paweł Rajba pawel@ii.uni.wroc.pl http://www.kursy24.eu/ Zawartość modułu 2 Kusory Wprowadzenie Kursory użytkownika Kursory domyślne Zmienne kursora Wyrażenia kursora - 2 - Wprowadzenie Co to jest kursor?
Trigger jest obiektem związanym z tablicą, który aktywuje się gdy do tablicy następuje odpowiednie zapytanie.
Temat: 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
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
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
Cheatsheet PL/SQL Andrzej Klusiewicz 1/9
Declare y integer; z varchar2(50); d date; null; Declare x integer:=10; null; x integer; x:=10; dbms_output.put_line('hello world'); for x in 1..10 loop Deklaracja 4 zmiennych. Jednej typu rzeczywistego,
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
Materiały. Technologie baz danych. Plan wykładu Kursory. Wykład 5: Kursory jawne. Podprogramy. Kursory jawne. Kursory niejawne
Materiały dostępne są na stronie: Materiały Technologie baz danych aragorn.pb.bialystok.pl/~gkret Wykład 5: Kursory jawne. Podprogramy. Małgorzata Krętowska Wydział Informatyki Politechnika Białostocka
Deklarowanie kursora
Kursory i wyjątki Kursory i praca z kursorami, kursory jawne i niejawne, otwieranie kursora, pobieranie z kursora, zamykanie kursora, wyjątki systemowe i użytkownika, zgłaszanie i obsługa wyjątków 1 Kursor
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
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
Procedury składowane. Funkcje vs. procedury Funkcja. Procedura. zazwyczaj ma parametry tylko typu IN; można wywoływać z poziomu
Procedury składowane Kolejnym typem programu języka PL/SQL są procedury składowane. Procedury mogą posiadać parametry typu IN, OUT lub IN OUT. Umożliwiają wykonanie operacji na danych w bazie, mogą też
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
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
41. Zmienne lokalne muszą mieć nazwę, którą poprzedza (maksymalnie 128 znaków) oraz typ (każdy z wyjątkiem: text, ntext oraz image)
Elementy języka T-SQL 40. Polecenie PRINT jest wykorzystywane do przekazania wiadomości tekstowej (maksymalna długość 8000 znaków) Przykład PRINT 'Aktualna data: '+convert(char(8),getdate()) PRINT 'Aktualny
Comarch ERP XL Business Intelligence Start. Migracja do wersji 2018
Business Intelligence Start Copyright 2018 COMARCH Wszelkie prawa zastrzeżone Nieautoryzowane rozpowszechnianie całości lub fragmentu niniejszej publikacji w jakiejkolwiek postaci jest zabronione. Wykonywanie
Tabele wykorzystywane w przykładach
Tabele wykorzystywane w przykładach create table departamenty( dep_id serial primary key, nazwa_departamentu text ); Tabele używane w wybranych przkładach create table pracownicy ( emp_id serial primary
Pakiety są logicznymi zbiorami obiektów takich jak podprogramy, typy, zmienne, kursory, wyjątki.
Pakiety Pakiety są logicznymi zbiorami obiektów takich jak podprogramy, typy, zmienne, kursory, wyjątki. Pakiet składa się ze: specyfikacji (interfejsu) i ciała (implementacji). W specyfikacji mieszczą
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
Ć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
Zaawansowane bazy danych i hurtownie danych semestr I
Podprogramy Wydział Informatyki Politechnika Białostocka Zaawansowane bazy danych i hurtownie danych semestr I Procedury do przeprowadzenia akcji Funkcje do obliczania wartości Pakiety do zbierania logicznie
Struktura bazy danych
Procedury składowane, funkcje i wyzwalacze Struktura bazy danych Tabela Oddziały ID Nazwa Adres 10 POZNAN Kwiatowa 3 20 WARSZAWA al. Jerozolimskie 22 30 KRAKOW Planty 14 40 WROCLAW Nad Odra 16 50 GDANSK
BAZY DANYCH Cz III. Transakcje, Triggery
BAZY DANYCH Cz III Transakcje, Triggery Transakcje Definicja: Zbiór operacji (modyfikacja danych, usuwanie, wstawianie, tworzenie obiektów bazodanowych), które albo wszystkie kończone są sukcesem, albo
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
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
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ść
050 SQL ELEMENTY ZAAWANSOWANE. Prof. dr hab. Marek Wisła
050 SQL ELEMENTY ZAAWANSOWANE Prof. dr hab. Marek Wisła Deklarowanie zmiennych DECLARE @nazwa-zmiennej typ-danych {, @nazwazmiennej typ-danych}; deklaruje nazwy zmiennych lokalnych (definiowanych przez
Języki programowania wysokiego poziomu. PHP cz.4. Bazy danych
Języki programowania wysokiego poziomu PHP cz.4. Bazy danych PHP i bazy danych PHP może zostać rozszerzony o mechanizmy dostępu do różnych baz danych: MySQL moduł mysql albo jego nowsza wersja mysqli (moduł
Deklarowanie kursora. CURSOR nazwa [ ( param1 typ1 [,param2 typ2]... ) ] [RETURN typ zwracany] IS zapytanie SQL;
Kursory Każde zapytanie SQL umieszczone w programie PLSQL jest wykonywane w tzw. obszarze roboczym lub inaczej obszarze kontekstu. PLSQL wykorzystuje ten obszar do przechowywania danych otrzymanych w wyniku
CREATE DATABASE ksiegarnia_internetowa DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;
Zestaw ćwiczeń1 Dzięki DDL (Data Definition Language) można operować na strukturach, w których dane są przechowywane czyli np. dodawać, zmieniać i kasować tabele lub bazy. Najważniejsze polecenia tej grupy
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
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
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>
Kursory. A. Pankowska 1
Kursory 1 Kursory Kursor jest mechanizmem pozwalającym obsłużyć zbiór zawierający wiele wierszy danych (generowany np. poleceniem SELECT). Jak wskaźnik przebiega on po kolejnych krotkach ze zbioru danych,
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
Język PL/SQL. Rozdział 2. Kursory
Język PL/SQL. Rozdział 2. Kursory Deklarowanie kursora, otwieranie kursora, pobieranie z kursora, zamykanie kursora, zmienne kursorowe, wyrażenie CURSOR, kursory niejawne. 1 Kursor jawny Każde zapytanie
Ref. 7 - Język SQL - polecenia DDL i DML
Ref. 7 - Język SQL - polecenia DDL i DML Wprowadzenie do języka SQL. Polecenia generujące strukturę bazy danych: CREATE, ALTER i DROP. Polecenia: wprowadzające dane do bazy - INSERT, modyfikujące zawartość
SQL :: Data Definition Language
SQL :: Data Definition Language 1. Zaproponuj wydajną strukturę danych tabela) do przechowywania macierzy o dowolnych wymiarach w bazie danych. Propozycja struktury powinna zostać zapisana z wykorzystaniem
1 Kursory 1. 2 Wyjątki Wyjątki predefiniowane Wyjątki niezdefiniowane wcześniej Definiowanie własnych wyjątków...
Plan wykładu Spis treści 1 Kursory 1 2 Wyjątki 4 2.1 Wyjątki predefiniowane............................. 4 2.2 Wyjątki niezdefiniowane wcześniej....................... 5 2.3 Definiowanie własnych wyjątków........................
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
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
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
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ę,
Plan wykładu BAZY DANYCH II WYKŁAD 3. Zasięg zmiennych. Zasięg zmiennych
Plan wykładu BAZY DANYCH II WYKŁAD 3 Zasięg zmiennych Zmienne powiązane Instrukcje warunkowe Pętle Pobieranie danych SQL w PL/SQL Rekordy dr inż. Agnieszka Bołtuć Zasięg zmiennych Zmienna jest dostępna
Obsługa błędów w SQL i transakcje. Obsługa błędów w SQL
Obsługa błędów w SQL i transakcje Zacznijmy od najprostszego przykładu: CREATE PROCEDURE podziel1 Obsługa błędów w SQL Powyższa procedura w większości przypadków zadziała prawidłowo, lecz na przykład poniższe
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 4 Wsady Procedury składowane Procedury składowane tymczasowe, startowe Zmienne tabelowe Funkcje
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
Kursor jawny. Rozdział 10a Kursory. Deklarowanie kursora (1) Deklarowanie kursora (2)
Kursor jawny Każde zapytanie SQL umieszczone w programie PL/SQL może zwrócić zero, jedną bądź wiele krotek. Aby efektywnie przetworzyć krotkizwrócone przez zapytanie korzystamy z kursorów. Kursor jest
1. ELEMENTY JĘZYKA PL/SQL
1. ELEMENTY JĘZYKA PL/SQL Aplikacje korzystające z PL/SQL będącego proceduralnym rozszerzeniem SQL mogą wykonywać procedury i funkcje języka PL/SQL składowane w bazie danych oraz wysyłać własne programy
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 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
PRZESTRZENNE BAZY DANYCH WYKŁAD 2
PRZESTRZENNE BAZY DANYCH WYKŁAD 2 Baza danych to zbiór plików, które fizycznie przechowują dane oraz system, który nimi zarządza (DBMS, ang. Database Management System). Zadaniem DBMS jest prawidłowe przechowywanie