Elementy. języka SQL



Podobne dokumenty
Kursory. A. Pankowska 1

W SQL Serwerze 2008 wprowadzono parametry tablicowe (Table Valued Parameters - TVP).

SQL język baz danych przegląd

Paweł Rajba

Blaski i cienie wyzwalaczy w relacyjnych bazach danych. Mgr inż. Andrzej Ptasznik

Administracja i programowanie pod Microsoft SQL Server 2000

Programowanie w SQL procedury i funkcje. UWAGA: Proszę nie zapominać o prefiksowaniu nazw obiektów ciągiem [OLIMP\{nr indeksu}] Funkcje użytkownika

Systemowe aspekty baz

Wyzwalacz - procedura wyzwalana, składowana fizycznie w bazie, uruchamiana automatycznie po nastąpieniu określonego w definicji zdarzenia

E.14 Bazy Danych cz. 18 SQL Funkcje, procedury składowane i wyzwalacze

050 SQL ELEMENTY ZAAWANSOWANE. Prof. dr hab. Marek Wisła

SQL 4 Structured Query Lenguage

Administracja i programowanie pod Microsoft SQL Server 2000

Programowanie w SQL. definicja bloku instrukcji BEGIN...END, warunkowe wykonanie instrukcji IF...ELSE, wyrażenie CASE,

DECLARE VARIABLE zmienna1 typ danych; BEGIN

SQL język baz danych przegląd

Systemowe aspekty baz danych

Sprawdzenie poziomu izolacji transakcji (w aktualnym połączeniu):

Przykład 3 Zdefiniuj w bazie danych hurtownia_nazwisko przykładową funkcję użytkownika fn_rok;

3 Przygotowali: mgr inż. Barbara Łukawska, mgr inż. Maciej Lasota

Język T-SQL część III programowanie bazy danych

Procedury i funkcje składowane

PODSTAWY BAZ DANYCH 13. PL/SQL

Bazy danych 10. SQL Widoki

Administracja i programowanie pod Microsoft SQL Server 2000

BAZY DANYCH Cz III. Transakcje, Triggery

Struktura bazy danych

Język PL/SQL Procedury i funkcje składowane

Procedury wyzwalane. (c) Instytut Informatyki Politechniki Poznańskiej 1

Bazy danych. Bazy danych. Zapytania SELECT. Dr inż. Paweł Kasprowski.

Wykład 5 funkcje i procedury pamiętane widoki (perspektywy) wyzwalacze

na MS SQLServer 2005 i 2008

Pakiety podprogramów Dynamiczny SQL

15. Funkcje i procedury składowane PL/SQL

Relacyjne bazy danych. Podstawy SQL

Język PL/SQL. Rozdział 5. Pakiety podprogramów. Dynamiczny SQL

Literatura: SQL Ćwiczenia praktyczne Autor: Marcin Lis Wydawnictwo: Helion. Autor: Joanna Karwowska

Bazy Danych i Usługi Sieciowe

Wykład 5 funkcje i procedury pamiętane widoki (perspektywy) wyzwalacze

Microsoft SQL Server Podstawy T-SQL

Hurtownia Świętego Mikołaja projekt bazy danych

Bazy danych i usługi sieciowe

Bazy danych wykład dwunasty PL/SQL, c.d. Konrad Zdanowski ( Uniwersytet Kardynała Stefana Bazy danych Wyszyńskiego, wykładwarszawa)

Relacyjne bazy danych. Podstawy SQL

Używany kiedy pełna treść instrukcji SQL jest nieznana przed uruchomieniem programu.

Bazy danych. Bazy danych. Podstawy języka SQL. Dr inż. Paweł Kasprowski.

DECLARE <nazwa_zmiennej> typ [(<rozmiar> )] [ NOT NULL ] [ { := DEFAULT } <wartość> ];

T-SQL dla każdego / Alison Balter. Gliwice, cop Spis treści. O autorce 11. Dedykacja 12. Podziękowania 12. Wstęp 15

Oracle PL/SQL. Paweł Rajba.

SQL Server i T-SQL w mgnieniu oka : opanuj język zapytań w 10 minut dziennie / Ben Forta. Gliwice, Spis treści

Materiały. Technologie baz danych. Plan wykładu Kursory. Wykład 5: Kursory jawne. Podprogramy. Kursory jawne. Kursory niejawne

P o d s t a w y j ę z y k a S Q L

UPDATE Studenci SET Rok = Rok + 1 WHERE Rodzaj_studiow =' INŻ_ST'; UPDATE Studenci SET Rok = Rok 1 WHERE Nr_albumu IN ( '111345','100678');

Wyzwalacze. do automatycznego generowania wartości kluczy głównych. Składnia instrukcji tworzacej wyzwalacz

Programowanie po stronie serwera w SZBD. Robert A. Kłopotek Wydział Matematyczno-Przyrodniczy. Szkoła Nauk Ścisłych, UKSW

Aspekty aktywne baz danych

Bloki anonimowe w PL/SQL

Tworzenie tabel. Bazy danych - laboratorium, Hanna Kleban 1

Laboratorium nr 4. Temat: SQL część II. Polecenia DML

Przestrzenne bazy danych Podstawy języka SQL

Systemy GIS Tworzenie zapytań w bazach danych

Plan bazy: Kod zakładający bazę danych: DROP TABLE noclegi CASCADE; CREATE TABLE noclegi( id_noclegu SERIAL NOT NULL,

Podstawy języka T-SQL : Microsoft SQL Server 2016 i Azure SQL Database / Itzik Ben-Gan. Warszawa, Spis treści

PRZESTRZENNE BAZY DANYCH WYKŁAD 2

Instrukcja podwaja zarobki osób, których imiona zaczynają się P i dalsze litery alfabetu zakładamy, że takich osbób jest kilkanaście.

BAZA DANYCH SIECI HOTELI

Ćwiczenia laboratoryjne nr 11 Bazy danych i SQL.

Język SQL. Rozdział 10. Perspektywy Stosowanie perspektyw, tworzenie perspektyw prostych i złożonych, perspektywy modyfikowalne i niemodyfikowalne.

SQL (ang. Structured Query Language)

41. Zmienne lokalne muszą mieć nazwę, którą poprzedza (maksymalnie 128 znaków) oraz typ (każdy z wyjątkiem: text, ntext oraz image)

Oracle PL/SQL. Paweł Rajba.

Ćwiczenia 2 IBM DB2 Data Studio

Składowane procedury i funkcje

Projektowanie systemów baz danych

Paweł Rajba

Wykład 8. SQL praca z tabelami 5

Perspektywy Stosowanie perspektyw, tworzenie perspektyw prostych i złożonych, perspektywy modyfikowalne i niemodyfikowalne, perspektywy wbudowane.

Wykład 5. SQL praca z tabelami 2

Bazy danych. Dr inż. Paweł Kasprowski

Bazy danych. Wykład IV SQL - wprowadzenie. Copyrights by Arkadiusz Rzucidło 1

Kursory i wyjątki. (c) Instytut Informatyki Politechniki Poznańskiej 1

Język DML. Instrukcje DML w różnych implementacjach SQL są bardzo podobne. Podstawowymi instrukcjami DML są: SELECT INSERT UPDATE DELETE

Bazy danych. dr inż. Arkadiusz Mirakowski

Język SQL. Rozdział 8. Język manipulowania danymi DML

Cele. Definiowanie wyzwalaczy

Język PL/SQL. Rozdział 2. Kursory

Kursor jawny. Rozdział 10a Kursory. Deklarowanie kursora (1) Deklarowanie kursora (2)

Comarch ERP XL Business Intelligence Start. Migracja do wersji 2018

Funkcje w PL/SQL Funkcja to nazwany blok języka PL/SQL. Jest przechowywana w bazie i musi zwracać wynik. Z reguły, funkcji utworzonych w PL/SQL-u

SQL Server Łukasz Łysik 21 października 2008

Język SQL, zajęcia nr 1

Tworzenie widoku CREATE OR REPLACE VIEW [nazwa_widoku] AS SELECT [nazwy_kolumn] FROM [nazwa_tablicy];

Kursor. Rozdział 10a Kursory. Otwieranie kursora. Deklarowanie kursora

Język PL/SQL. Rozdział 6. Procedury wyzwalane

INTERNETOWE BAZY DANYCH materiały pomocnicze - wykład X

1. Wyzwalacze BD (ang. triggers)

Bazy danych i usługi sieciowe

Zaawansowane bazy danych i hurtownie danych semestr I

KOLEKCJE - to typy masowe,zawierające pewną liczbę jednorodnych elementów

Transkrypt:

Elementy języka SQL

SQL SQL - Structured Query Language język czwartej generacji (4GL), opracowany w latach 70-tych przez IBM strukturalny język zapytań, przeznaczony do definiowania, wyszukiwania i administrowania danymi w relacyjnej bazie danych. Rodzaje instrukcji: DDL CREATE, DROP, ALTER DML SELECT, INSERT, UPDATE, DELETE DCL GRANT, DENY, REVOKE Transact-SQL (T-SQL) jest zmodyfikowaną wersją standardu SQL-92, uzupełnioną o elementy typowe dla proceduralnych języków programowania, takie jak zmienne i instrukcje sterujące A. Pankowska 2

SQL trzy formy Postać poleceń SQL: Interakcyjny SQL - bezpośrednie pobieranie lub wprowadzanie informacji do bazy Statyczny kod SQL Osadzony SQL (Embedded SQL) - włączenie kodu SQL do kodu źródłowego innego języka; wykorzystanie zmiennych Język modułów - moduły kodu SQL łączone są z modułami kodu w innym języku Dynamiczny kod SQL - generowany jest w trakcie pracy aplikacji A. Pankowska 3

SQL interakcyjny Zapytanie w trybie interakcyjnym, bezpośrednio z terminala; przykład mediana: create view tmp1 as select placa_pod from pracownicy union all select placa_pod from pracownicy create view tmp2 as select placa_pod from tmp1 t1 where (select count(*) from pracownicy) <= (select count(*) from tmp1 t2 where t2.placa_pod >= t1.placa_pod) and (select count(*) from pracownicy) <= (select count(*) from tmp1 t3 where t3.placa_pod <= t1.placa_pod) select avg(distinct placa_pod) from tmp2 A. Pankowska 4

SQL statyczny Zapytanie sparametryzowane (z wykorzystaniem zmiennych) declare @IDPrac int declare @placa money set @IDPrac = 210 select @placa = Placa from Pracownik where IDPrac = @IDPrac A. Pankowska 5

SQL dynamiczny Zapytanie dynamiczne (tworzone dynamicznie) declare @zm_zapytanie varchar(100) declare @zm_tabela varchar(100) declare @zm_kolumny varchar(100) set @zm_tabela = 'Pracownicy' set @zm_kolumny = 'Nazwisko, Placa_pod' set @zm_zapytanie = 'select ' + @zm_kolumny + ' from ' + @zm_tabela execute sp_sqlexec @zm_zapytanie A. Pankowska 6

SQL dynamiczny W przypadku zapytań dynamicznych postać zapytania nie jest znana na etapie kompilacji, w szczególności więc system nie jest w stanie ani sprawdzić poprawności składniowej zapytania, ani tym bardziej opracować optymalnej strategii jego wykonania. Czynności te realizowane są dopiero na etapie wykonania, co istotnie zmniejsza efektywność przetwarzania. A. Pankowska 7

Programowanie SQL Servera Dla wykonywania obliczeń, których nie można wyrazić za pomocą pojedynczego wyrażenia w języku Transact- SQL (T-SQL), stosuje się: paczki (wsady) (batches) i skrypty (scripts), systemowe procedury pamiętane (system stored procedures), procedury pamiętane (składowane) (stored procedures), funkcje (functions), procedury wyzwalane (trigery) (triggers), kursory (cursors). A. Pankowska 8

Paczki (batches) Paczka stanowi grupę złożoną z jednej lub z wielu wyrażeń Transact- SQLa. Standardowym końcem paczki jest polecenie GO lub koniec pliku. Paczkę może też stanowić grupa podświetlonych czy zaznaczonych wyrażeń (przy korzystaniu z Query Analyser). SQL Server kompiluje paczkę w pojedynczą jednostkę wykonywalną zwaną planem wykonania (execution plan). Wyrażenia tworzące plan wykonania wykonywane są jednorazowo w jednym czasie. W przypadku wystąpienia błędu kompilacji, żadne z wyrażeń w paczce nie zostanie wykonane. Zmienna zdefiniowana w paczce nie jest dostępna poza nią zmienne są lokalne w paczce. Nie wszystkie wyrażenia mogą występować jednocześnie w jednej paczce (np. definiowanie i wywoływanie procedury). A. Pankowska 9

Paczki i skrypty Przykład skryptu złożonego z dwóch paczek: USE sklep GO -- wykonanie paczki, wybór bazy sklep DECLARE @Powitanie VARCHAR(50) SET @Powitanie = 'Witaj w sklepie!' print @Powitanie GO -- wykonanie paczki A. Pankowska 10

Systemowe procedury pamiętane Nazwy wszystkich systemowych procedur pamiętanych rozpoczynają się od sp_ lub xp_. Systemowe procedury pamiętane są prekompilowanymi zbiorami wyrażeń SQL-owych ( sp_, zapisane w bazie Master) lub języka programowanie ( xp_, pliki bibliotek dynamicznych dll). Przykłady: EXEC sp_addtype PESEL, 'VARCHAR(11)', 'NOT NULL EXEC sp_help EXEC sp_addextendedproc xp_hello, 'xp_hello.dll A. Pankowska 11

Procedury pamiętane Procedury składowane są zbiorami instrukcji języka Transact-SQL zapisanymi pod wspólną nazwą i wywoływanymi jak pojedyncza instrukcja Możliwe jest tworzenie własnych procedur składowanych przechowywanych w bazie użytkownika oraz tymczasowych procedur składowanych (które rozpoczynają się znakiem #). A. Pankowska 12

Przetwarzanie procedur przez SQL Server Tworzenie: sprawdzenie poprawności syntaktycznej nowo utworzonej procedury treść zostaje zapisana w tabeli systemowej syscomments, a jej nazwa w tabeli sysobjects select c.text from sysobjects o, syscomments c where o.id = c.id and o.name = 'Podwyzka Pierwsze wykonanie Sprawdzenie poprawności semantycznej Optymalizacja planu wykonania procedury Kompilacja wybranego planu wykonania A. Pankowska 13

Procedury pamiętane CREATE PROC [EDURE] procedura [; numer] [{@parametr typ_danych} [VARYING] [= wartość_domyślna] [OUTPUT] ] [, n] [WITH {RECOMPILE ENCRYPTION RECOMPILE, ENCRYPTION}] [FOR REPLICATION] AS instrukcja_sql [ n] A. Pankowska 14

Procedury pamiętane W ciele procedury niedozwolone jest umieszczanie następujących instrukcji: CREATE DEFAULT, CREATE PROCEDURE, CREATE RULE, CREATE TRIGGER CREATE VIEW. A. Pankowska 15

Procedury pamiętane Procedura oblicza dochód w podanym okresie: CREATE PROC dochod @idprac int, @czas int, @wynik int OUTPUT -- parametr wyjsciowy as select @wynik = (pensja + premia)*@czas from pracownik where IdPrac = @idprac Wywołanie: declare @c int, @w int set @c = 12 exec dochod 1,@c,@w output select cast(@c as varchar(4))+' miesiecy' as [dochod za okres], cast(@w as varchar(11))+' zl' as wynosi Wynik: dochod za okres wynosi -------------------- -------- 12 miesiecy 14400 zl A. Pankowska 16

Rodzaje funkcji: Funkcje funkcje skalarne (scalar user-defined functions) zwracaną wartością jest pojedyncza liczba lub tekst, tj. wartość dowolnego typu z wyjątkiem typów: text, ntext i image; proste funkcje tablicowe (inline table-valued functions) zwracają wartość typu TABLE, przy czym zwracana tabela jest określona za pomocą pojedynczego wyrażenia SELECT (funkcje te nazywane są sparametryzowanymi widokami); złożone funkcje tablicowe (multi-statement table-valued functions) zwracają zmienną typu TABLE, przy czym zwracana tabela jest dowolną tabelą utworzoną w ciele funkcji. A. Pankowska 17

Funkcje skalarne Funkcja zwraca największy numer pracownika z podanego działu: CREATE FUNCTION ostatni_prac_dzialu (@id int) RETURNS int BEGIN declare @nr int set @nr = (select max(idprac) from pracownik where IdDzialu=@id) RETURN @nr END Wykorzystanie funkcji: select * from pracownik where IdPrac = dbo.ostatni_prac_dzialu(1) A. Pankowska 18

Proste funkcje tablicowe Funkcja zwraca zbiór pracowników z działu o podanym identyfikatorze: create function prac_dzialu(@id int) RETURNS TABLE as RETURN(select * from pracownik where IdDzialu=@id) go Wykorzystanie funkcji (wywołanie funkcji występuje w roli tabeli): select * from dbo.prac_dzialu(2) A. Pankowska 19

Złożone funkcje tablicowe Funkcja zwraca listę dobrze zarabiających pracowników: create function krezus(@z int) RETURNS @lista table (id int PRIMARY KEY, nazwisko varchar(22), dochod int) as begin if @z > 5000 insert @lista select id_prac,nazwisko,zarobki from pracownik1 where zarobki > @z RETURN end Wykorzystanie funkcji: select * from krezus(5500) select * from krezus(1000) - tabela pusta A. Pankowska 20

Procedury wyzwalane (trigery) Procedury wyzwalane (trigery): wywoływane są automatycznie w wyniku wykonania operacji: INSERT, UPDATE lub DELETE, można specyfikować operację, która wykona się zamiast operacji głównej wariant INSTEAD OF, są być przypisane do tabeli lub widoku, wykorzystują systemowe tabele INSERTED i/lub DELETED (INSERTED zawiera dołączane krotki lub nową wersję krotek zmienianych; DELETED zawiera usuwane krotki lub starą wersję krotek zmienianych), rozszerzają możliwości definiowania warunków spójności, mogą być wywoływane rekurencyjnie A. Pankowska 21

Procedury wyzwalane (trigery) Wyzwalacze umożliwiają m.in.: Kaskadowe aktualizowanie danych w powiązanych tabelach Sprawdzanie poprawności danych na podstawie wartości przechowywanych w dowolnych tabelach Jednoczesne sprawdzanie danych zmodyfikowanych w dowolnej liczbie wierszy tabeli Wywoływanie predefiniowanych lub zdefiniowanych przez użytkownika komunikatów błędu Monitorowanie aktywności użytkowników Modyfikacje danych w bazach niespełniających wymogów trzeciej postaci normalnej. A. Pankowska 22

Procedury wyzwalane - przykład Zakaz dopisania pracownika, który zarabia więcej niż jego kierownik: create trigger sprawdz on pracownicy for insert as if (select placa_pod from inserted) > (select k.placa_pod from pracownicy k,inserted i where k.id_prac = i.szef) begin rollback end A. Pankowska 23

Procedury wyzwalane INSTEAD OF Trigger zaznacza w kolumnie del elementy przeznaczone do usunięcia: create trigger zaznacz on Pracownik INSTEAD OF delete as update Pracownik set del='*' where nazwisko in (select nazwisko from deleted) go delete from Pracownik where nazwisko like 'K% Wynik: nazwisko premia del -------------------- ----------- ---- Kowalski 200 * Lipski 200 NULL Kowal 200 * Pawlak 200 NULL A. Pankowska 24

Kursory Kursor (ang. cursor) dostarcza mechanizmu dostępu do pojedynczych wierszy wg zasady "jeden po drugim". Składnia SQL-92 DECLARE nazwa_kursora [INSENSITIVE] [SCROLL] CURSOR FOR wyrażenie_select [FOR {READ ONLY UPDATE [OF nazwa_kolumny [,...n]]}] Składnia Transact-SQL: DECLARE nazwa_kursora CURSOR [LOCAL GLOBAL] [FORWARD_ONLY SCROLL] [STATIC KEYSET DYNAMIC FAST_FORWARD] [READ_ONLY SCROLL_LOCKS OPTIMISTIC] [TYPE_WARNING] FOR wyrażenie_select [FOR UPDATE [OF nazwa_kolumny [,...n]]] A. Pankowska 25

declare @nazwisko varchar(20) declare kursor cursor for select nazwisko from pracownicy open kursor fetch next from kursor into @nazwisko while @@fetch_status = 0 begin print @nazwisko fetch next from kursor into @nazwisko end close kursor deallocate kursor go Kursory Aby przetwarzać dane za pomocą kursora należy: zadeklarować kursor DECLARE... CURSOR i zdefiniować jego zakres FOR SELECT otworzyć kursor, OPEN - wykonywana jest operacja SELECT, kursor wskazuje na miejsce bezpośrednio przed pierwszym wierszem w utworzonym zbiorze wierszy wykonać operację pobrania danych na kolejnym wierszu FETCH NEXT FROM, pobierane dane można zapamiętać pod podanymi zmiennymi pobieranie danych może być realizowane w pętli, różna od zera wartość zmiennej (funkcji) globalnej @@FETCH_STATUS może kończyć wykonywanie operacji pobierania danych w końcu kursor należy zamknąć CLOSE i dealokować DEALLOCATE A. Pankowska 26

Widoki (perspektywy, views) Pracownicy Dzialy id_prac nazwisko stanowisko szef zatrudniony placa_pod placa_dodid_dzialu 100 WEGLARZ DYREKTOR NULL 1968-01-01 1730.0000 420.5000 10 110 BLAZEWICZ PROFESOR 100 1973-05-01 1350.0000 210.0000 40 id_dzialu nazwa adres 10 ADMINISTRACJA PIOTROWO 3A 20 SYSTEMY ROZPROSZONE PIOTROWO 3A 30 SYSTEMY EKSPERCKIE STRZELECKA 14 create view dane_pracownika as select nazwisko, nazwa as dzial, stanowisko from pracownicy p, dzialy d where p.id_dzialu = d.id_dzialu select * from dane_pracownika nazwisko dzial stanowisko WEGLARZ ADMINIS TRACJA DYREKTOR BLAZEWICZ ALGORYTMY P ROFES OR A. Pankowska 27

Widoki Widoki są tabelami wirtualnymi (intencjonalnymi), nie mającymi bezpośredniej reprezentacji w bazie danych. Zapamiętana jest jedynie ich definicja. Definicja widoku wykorzystywana jest w momencie odwoływania się do niego jak do każdej innej tabeli. Widoki wykorzystywane są, aby: Ułatwić użytkownikom odczytywanie danych użytkownikom (pochodzących z kilku tabel bądź obliczanych) Ograniczyć, ze względów bezpieczeństwa, dostęp użytkowników do poufnych danych. Ukryć przed użytkownikami strukturę tabel bazy danych. Ułatwić zarządzanie uprawnieniami użytkowników. A. Pankowska 28

Widoki "Towary RTV w cenach sprzedaży " create view RTV (NrTow, Nazwa, CenaSprz) as select T.NrTow, T.Nazwa, T.CenaSprz from Towar T where T.GrupaTow = 'RTV Definicja widoku wykorzystywana jest w momencie odwoływania się do niego: select RTV.NrTow, RTV.Nazwa, RTV.CenaSprz from RTV where RTV.CenaSprz < 2000 Przekształcone jest do zapytania względem tabeli TOWAR: select RTV.NrTow, RTV.Nazwa, RTV.CenaSprz from (select T.NrTow, T.Nazwa, T.CenaSprz from Towar T where T.GrupaTow = 'RTV' ) RTV where RTV.CenaSprz < 2000 lub równoważnie: select T.NrTow, T.Nazwa, T.CenaSprz from Towar T where T.GrupaTow = 'RTV' and T.CenaSprz < 2000 A. Pankowska 29

Modyfikowalność widoków 1. Jeśli widok jest tak zdefiniowany, że można przetransformować operacje jego modyfikowania na modyfikację tabel bazowych, to można go aktualizować. 2. Sytuacja taka występuje na przykład wtedy, gdy w definicji kursora zawarto klucz główny tabel bazowych, nad którymi jest definiowany i nie zawiera funkcji agregujących ani słowa DISTINCT. A. Pankowska 30

Modyfikowalność widoków (c.d.) W przypadku widoku RTV, jego definicja create view RTV (NrTow, Nazwa, CenaSprz) as select T.NrTow, T.Nazwa, T.CenaSprz from Towar T where T.GrupaTow = 'RTV' zawiera klucz główny tabeli Towar. Można go więc modyfikować. Wówczas polecenie: update RTV set CenaSprz = CenaSprz + 10 zostanie wykonane i spowoduje odpowiednią modyfikację tabeli Towar. A. Pankowska 31

Modyfikowalność widoków (c.d.) Bardzo często widoki są niemodyfikowalne. Przykłady niemodyfikowalnych widoków: 1. Widok zawierający łączną ilość poszczególnych towarów we wszystkich dostawach: create view TD(NrTow, IlDost) as select W.NrTow, SUM(W.Ilosc) from Dostawa W group by W.NrTow Widok jest niemodyfikowalny, gdyż zawiera funkcję agregującą. A. Pankowska 32

Modyfikowalność widoków (c.d.) 2. Widok Miasta definiuje pary (DAdres, MAdres), gdzie DAdres jest adresem dostawcy, a MAdres jest adresem magazynu, do którego dostawca dostarcza towary: create view Miasta (DAdres, MAdres) as select distinct D.Adres, M.Adres from Dostawca D, Magazyn M, Dostawa W where D.NrDcy = W.NrDcy and M.NrMag = W.NrMag Widok ten jest niemodyfikowalny, gdyż zawiera słowo distinct. A. Pankowska 33

Modyfikowalność widoków (c.d.) Rozważmy widok jak poprzednio, ale bez słowa distinct: create view Miasta1 (DAdres, MAdres) as select D.Adres, M.Adres from Dostawca D, Magazyn M, Dostawa W where D.NrDcy = W.NrDcy and M.NrMag = W.NrMag A. Pankowska 34

Modyfikowalność widoków (c.d.) Miasta1 update Miasta1 set DAdres = 'Kraków' where DAdres = 'Poznań' Dostawca Widok Miasta1 jest modyfikowalny, gdyż zawarte w jego definicji warunki na kluczach głównych pozwalają dokonać odpowiednich modyfikacji na wyjściowych tabelach