Professional Documents
Culture Documents
Bazy Danych
Wykorzystano materiały:
http://www.postgresql.org/docs/8.3/interactive/
extend.html
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 2
Drzewo zapytania
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 3
Reguły
Przykłady reguł
Podmiana (trigger-rule-select-agr.sql)
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 6
Przykłady reguł
(trigger-rule-count-down.sql)
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 7
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 8
Przykłady reguł
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 10
Zastosowanie
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 11
Funkcje
Funkcje – podstawy
Definicj˛e funkcji podaje si˛e jako pojedynczy ciag˛ znaków, który może obej-
mować kilka wierszy. Można go zapisać w dowolnym j˛ezyku programowania
obsługiwanym przez PostgreSQL jako ładowalny j˛ezyk proceduralny. Po utwo-
rzeniu funkcji, jej definicja jest zapisywana w bazie danych.
Kiedy funkcja jest wywoływana po raz pierwszy, definicja funkcji jest kompi-
lowana przez program obsługi do postaci wykonywalnej, a nast˛epnie wykony-
wana. Dopiero użycie funkcji pozwala na wykrycie jej ewentualnych bł˛edów.
PostgreSQL uznaje funkcje za różne, jeżeli maja˛ one różne nazwy lub różna˛
liczb˛e parametrów, albo parametry sa˛ innego typu. Możemy zatem przecia˛żać
nazwy funkcji.
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 13
Funkcje w PostgreSQL
Znacznik SETOF powoduje, że funkcja może zwrócić wynik, który zawiera
wiele rekordów. W przypadku jego braku zwracany jest zawsze pojedynczy
rekord, lub wartość skalarna.
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 14
Znaczniki – znaczenie
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 16
select sqlf(’Kraków’);
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 17
Funkcje SQL
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 19
• anyelement,
• anyarray,
• anynonarray, oraz
• anyenum.
intarray textarray
1,2 a,b
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 20
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 21
PL/pgSQL – podstawy
[<<etykieta>>]
declare deklaracje
begin
instrukcje
end;
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 22
Bloki instrukcji
[ <<label>> ]
[ DECLARE
deklaracje ]
BEGIN
instrukcje
[ EXCEPTION --
WHEN warunek [ OR warunek ... ] THEN
obsluga wyjatku
[ WHEN warunek [ OR warunek ... ] THEN
obsluga wyjatku
... ] ]
END [ label ];
zwróconym wyniku z zapytania b˛edzie wi˛ecej niż jeden wiersz, lub wynik
b˛edzie pusty:
BEGIN
SELECT * INTO STRICT myrec
FROM prac WHERE nazwisko = myname;
EXCEPTION
WHEN NO_DATA_FOUND THEN
RAISE EXCEPTION ’prac % not found’, myname;
WHEN TOO_MANY_ROWS THEN
RAISE EXCEPTION ’prac % not unique’, myname;
END;
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 24
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 25
Przykład 2 – podstawy
begin
select into w sum(cena) from zamowienia
where idnadawcy = klient;
return w;
end;
$$
language plpgsql;
Wewnatrz
˛ funkcji PL/pgSQL można deklarować lokalne zmienne. Każda
zmienna musi mieć określony typ, który może być jednym z wbudowanych
typów PostgreSQL, typem użytkownika lub typem odpowiadajacym ˛ wierszowi
w tabeli.
Deklaracje zmiennych dla funkcji zapisuje si˛e w sekcji DECLARE definicji
funkcji lub w bloku wewnatrz
˛ funkcji. Zmienne zadeklarowane w bloku sa˛ wi-
doczne tylko wewnatrz
˛ niego oraz w innych blokach, które si˛e w nim znajduja.˛
Zmienna zadeklarowana w bloku wewn˛etrznym, posiadajaca ˛ t˛e sama˛ nazw˛e jak
zmienna na zewnatrz
˛ bloku, przesłania zmienna˛ zewn˛etrzna.˛
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 26
Przypisania – rekordy
wynik record;
select * into wynik from klienci where idklienta = 9;
if not found then
-- dzialania awaryjne
end if;
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 27
Wyrażenia
Dost˛ep do argumentów funkcji odbywa si˛e przez nazw˛e, jeżeli argument jest
nazwany, lub przez alias utworzony w sekcji deklaracji:
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 28
Instrukcje sterujace
˛
RETURN wyrazenie;
Jeżeli w definicji funkcji został użyty znacznik SETOF to konieczne jest zasto-
sowanie jednego z poleceń:
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 29
Instrukcje warunkowe
IF wyrazenie-logiczne-1 THEN
instrukcje-1
[ ELSIF wyrazenie_logiczne-2 THEN
instrukcje-2 ]
[ ELSIF wyrazenie-logiczne-3 THEN
instrukcje-3 ]
[ ELSE
instrukcje ]
END IF;
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 30
P˛etle – podstawy
[<<etykieta>>]
loop
instrukcje
end loop;
<<infinite>>
loop
n:=n+l;
exit infinite when n>=10;
end loop;
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 31
while wyrazenie
loop
instrukcje
end loop;
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 32
P˛etle
Postać p˛etli:
[ <<label>> ]
LOOP
instrukcje
[ CONTINUE [ label ] [ WHEN wyrazenie-logiczne-1 ] ];
[ EXIT [ label ] [ WHEN wyrazenie-logiczne-2 ] ];
END LOOP [ label ]
[ <<label>> ]
WHILE wyrazenie-logiczne LOOP
instrukcje
END LOOP [ label ];
[ <<label>> ]
FOR zmienna IN [ REVERSE ]
wyrazenie-poczatek .. wyrazenie-koniec
[ BY wyrazenie-krok ] LOOP
instrukcje
END LOOP [ label ];
[ <<label>> ]
FOR zmienna-record IN zapytanie-select LOOP
instrukcje
END LOOP [ label ];
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 33
Wywoływanie wyjatków
˛
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 34
Przykładowa funkcja
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 35
Przykład wywołania
nazwisko nadplata
Kowal t
Kowalski f
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 36
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 37
Funkcje w C
#include <postgres.h>
#include <executor/executor.h> /*GetAttributeByName()*/
#ifdef PG_MODULE_MAGIC
PG_MODULE_MAGIC;
#endif
PG_FUNCTION_INFO_V1(c_nadplata);
Datum
c_nadplata(PG_FUNCTION_ARGS)
{
HeapTupleHeader t = PG_GETARG_HEAPTUPLEHEADER(0);
/*Wiersz tabeli*/
int32 limit = PG_GETARG_INT32(1);
bool isnull;
Datum salary;
Kompilacja
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 39
-- przyklad wolania
nazwisko nadplata
Kowal f
Kowalowski t
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
1
http://www.postgresql.org/docs/8.3/interactive/spi.html
PostgreSQL 40
• INSERT,
• UPDATE,
• DELETE.
• BEFORE,
• AFTER,
czyli dla każdego wiersza, którego dotyczy działanie lub raz dla całej instrukcji.
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 41
Wyzwalacze – podstawy
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 42
Wyzwalacze
Funkcje j˛ezyka PL/pgSQL bardzo cz˛esto wykorzystuje si˛e do pisania tak zwa-
nych wyzwalaczy, czyli elementów aktywnych, które podobnie jak reguły sa˛
wykonywane gdy wystapi ˛ odpowiednie zdarzenie.
Deklaracja wyzwalacza wymaga uprzedniego zdefiniowania funkcji!
Wyzwalacze różnia˛ si˛e od reguł j˛ezykiem w którym sa˛ tworzone (reguły wy-
korzystuja˛ składnie SQL). Dzi˛eki zastosowaniu funkcji PL/pgSQL wyzwalacze
moga˛ modyfikować, lub nawet odwołać działanie instrukcji które je urucha-
miaja.˛
Jedna˛ funkcj˛e można użyć do deklaracji kilku wyzwalaczy:
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 43
Wyzwalacze – uwagi
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 44
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 45
Przykład – podstawy
begin
update kompozycje set stan = stan - 1
where idkompozycji = new.idkompozycji;
if s = 1 then
insert into zapotrzebowanie
values(new.idkompozycji, current_date, null);
end if;
return null;
end;
$$
language plpgsql;
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 46
Przykład
Przykład
Przy próbie zmiany wartości kolumny kierownik w tabeli dzial na taka,˛ która
nie istnieje w tabeli prac, automatycznie zostaje dodany wiersz do tabeli prac:
PostgreSQL 48
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 49
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 50
Funkcje agregujace
˛
Majac ˛ a˛2 ,
˛ dana˛ zdefiniowana˛ funkcj˛e możemy zdefiniować funkcj˛e agregujac
skutkiem czego b˛edzie można ja˛ wykorzystać w zapytania SQL w celu dokona-
nia operacji na grupie rekordów:
CREATE TYPE complex AS ( x real,
y real);
CREATE TABLE complex_tab (
val complex
);
INSERT INTO complex_tab (val) VALUES((1,2.3));
INSERT INTO complex_tab (val) VALUES((1,2));
CREATE FUNCTION complex_add(c1 complex, c2 complex)
RETURNS complex AS $BODY$
DECLARE
ret complex;
BEGIN
ret.x := c1.x + c2.x;
ret.y := c1.y + c2.y;
RETURN ret;
END; $BODY$
LANGUAGE ’plpgsql’;
CREATE AGGREGATE complex_sum(
BASETYPE=complex, SFUNC=complex_add,
STYPE=complex, INITCOND=’(0,0)’
);
SELECT complex_sum(val) AS sum FROM complex_tab;
sum
(2,4.3)
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
2
http://www.postgresql.org/docs/8.3/interactive/xaggr.html
PostgreSQL 51
Operatory
CREATE OPERATOR + (
leftarg = complex,
rightarg = complex,
procedure = complex_add,
commutator = +
);
SELECT (val + val) AS m FROM complex_tab;
m
(2,4.6)
(4,4.6)
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
3
http://www.postgresql.org/docs/8.3/interactive/xoper.html
PostgreSQL 52
Interfejs indeksu
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
4
http://www.postgresql.org/docs/8.3/interactive/xindex.html
PostgreSQL 53
Przykład
END;
$BODY$
LANGUAGE ’plpgsql’ IMMUTABLE STRICT;
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 55
C.d.
Przykład użycia:
val
(1,2.3)
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 56
Materializacja widoków
• Na żadanie
˛ użytkownika,
• Co pewien interwał czasowy,
• Po każdej modyfikacji tabel, których kolumny buduja˛ widok.
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
5
http://www.varlena.com/GeneralBits/Tidbits/matviews.html
PostgreSQL 57
C.d.
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 58
C.d.
Antoni
c Lig˛eza, Marcin Szpyrka, Sławomir Lichoń
PostgreSQL 59
C.d.