Zarządzanie obiektami bazy danych Oracle11g



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

Bazy danych - Materiały do laboratoriów VIII

Wykład 8. SQL praca z tabelami 5

Zbiór pytań nr 2. 1 Tabela DEPARTMENTS ma następującą strukturę:

Zarządzanie obiektami bazy danych Oracle11g

I. Język manipulowania danymi - DML (Data Manipulation Language). Polecenia INSERT, UPDATE, DELETE

Autor: Joanna Karwowska

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

Bazy danych 9. SQL Klucze obce Transakcje

startup pfile= '$HOME/admin/pfile/initDBx.ora'; create spfile from pfile= '$HOME/admin/pfile/initDBx.ora';

Język SQL. Rozdział 9. Język definiowania danych DDL, część 2.

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

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

Język SQL, zajęcia nr 1

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

Bazy danych wykład szósty Więzy i wyzwalacze. Konrad Zdanowski ( Uniwersytet Kardynała Stefana Bazy danych Wyszyńskiego, wykładwarszawa)

Rozdział 17. Zarządzanie współbieżnością zadania dodatkowe

1 Zaznacz poprawne stwierdzenia dotyczące grup plików (filegroup) możemy określić do której grupy plików trafi

Bazy danych 6. Klucze obce. P. F. Góra

Tworzenie tabeli przez select CREATE TABLE PRAC2 AS SELECT P.NAZWISKO, Z.NAZWA FROM PRAC P NATURAL JOIN ZESP Z

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

Wprowadzenie do projektowania i wykorzystania baz danych Relacje

Zarządzanie strukturą bazy danych Oracle11g

SQL DDL DML TECHNOLOGIE BAZ DANYCH. Wykład 5: Język DDL i DML. Małgorzata Krętowska

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

Ustawienie na poziomie sesji (działa do zmiany lub zakończenia sesji zamknięcia połączenia).

Rozdział 17. Zarządzanie współbieżnością zadania

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

Bazy danych 9. Klucze obce Transakcje

Bazy danych 9. Klucze obce Transakcje. P. F. Góra

Uprawnienia, role, synonimy

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

Tworzenie tabel. Bazy danych - laboratorium, Hanna Kleban 1

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

Wykład V. Indeksy. Struktura indeksu składa się z rekordów o dwóch polach

Projektowanie systemów baz danych

Bazy danych wykład dziewiaty Transakcje. Konrad Zdanowski ( Uniwersytet Kardynała Stefana Bazy danych Wyszyńskiego, wykładwarszawa)

Cwiczenie 7. Retrospekcja

1 Przetwarzanie transakcyjne Cechy transakcji Rozpoczęcie i zakończenie Punkty bezpieczeństwa... 3

Pakiety podprogramów Dynamiczny SQL

Zbiór pytań nr 5. 2 Które stwierdzenie opisuje najlepiej zbiór uprawnień dostępny po wykonaniu

Plan ćwiczenia. Rozdział 17. zarządzania współbieżnością. Dostęp współbieżny a dostęp spójny. Spójność bazy danych

Paweł Rajba

Aspekty aktywne baz danych

1 Projekt fizyczny 1. 3 Perspektywy słownika danych Źródła 12

Server Oracle - System Zarządzania Bazą Danych - składa się z instancji Oracle i bazy danych Oracle Instancja Oracle - pewne procesy drugoplanowe i

przykłady problemów; realizacja dostaw części od producenta do klienta:

Wprowadzenie do BD Operacje na bazie i tabelach Co poza zapytaniami? Algebra relacji. Bazy Danych i Systemy informacyjne Wykład 2.

kończy wysyłanie danych do pliku tworzy strukturę tabeli wyświetla opis struktury tabeli zmiana nazwy tabeli usuwanie tabeli

Wykład 05 Bazy danych

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

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

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

Oracle11g: Wprowadzenie do SQL

Integralność danych Wersje języka SQL Klauzula SELECT i JOIN

Zarzadzanie transakcjami. Transakcje

PRZESTRZENNE BAZY DANYCH WYKŁAD 2

Plan ćwiczenia. Rozdział 17 Zarządzanie współbieżnością. Dostęp współbieżny a dostęp spójny. Spójność bazy danych

D D L S Q L. Co to jest DDL SQL i jakie s jego ą podstawowe polecenia?

Ćwiczenia laboratoryjne nr 11 Bazy danych i SQL.

Przykładowa baza danych BIBLIOTEKA

Bazy danych. Dr inż. Paweł Kasprowski

SQL w języku PL/SQL. 2) Instrukcje języka definicji danych DDL DROP, CREATE, ALTER, GRANT, REVOKE

Język SQL. Rozdział 9. Język definiowania danych DDL, część 2. zadania

DECLARE VARIABLE zmienna1 typ danych; BEGIN

Widok Connections po utworzeniu połączenia. Obszar roboczy

Plan wykładu BAZY DANYCH II WYKŁAD 3. Zasięg zmiennych. Zasięg zmiennych

Internetowe bazy danych

SELECT * FROM tabela WHERE warunek wybiera dane spełniające podany warunek

Przygotowanie bazy do wykonywania kopii bezpieczeństwa

SQL :: Data Definition Language

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

Bazy danych Ćwiczenia projektowe

SQL> startup pfile=./admin/pfile/initdbx.ora. SQL> create spfile from pfile='$home/admin/pfile/initdbx.ora' create user bolek identified by bolek;

Instytut Mechaniki i Inżynierii Obliczeniowej Wydział Mechaniczny Technologiczny Politechnika Śląska

Ile rekordów będzie zawierała tabela przy założeniu, że na początku była pusta?

Procedury składowane. Funkcje vs. procedury Funkcja. Procedura. zazwyczaj ma parametry tylko typu IN; można wywoływać z poziomu

Transakcje. (c) Instytut Informatyki Politechniki Poznańskiej

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

Bazy Danych II. Ćwiczenia

1. Wyzwalacze BD (ang. triggers)

Bazy danych 10. SQL Widoki

PL/SQL. Zaawansowane tematy PL/SQL. Piotr Medoń

Oracle PL/SQL. Paweł Rajba.

Obiekty bazy danych DB2

Bazy danych Język SQL część 1 Wykład dla studentów matem

77. Modelowanie bazy danych rodzaje połączeń relacyjnych, pojęcie klucza obcego.

PLAN WYKŁADU BAZY DANYCH PODSTAWOWE KWESTIE BEZPIECZEŃSTWA OGRANICZENIA DOSTĘPU DO DANYCH

1. Połączenie z bazą danych. W wybranym edytorze tworzymy plik sqltest.py i umieszczamy w nim poniższy kod. #!/usr/bin/python3 import sqlite3

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

Zarządzanie użytkownikami bazy danych Oracle11g

Bazy danych. Polecenia SQL

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

Bazy danych. Plan wykładu. Rozproszona baza danych. Fragmetaryzacja. Cechy bazy rozproszonej. Replikacje (zalety) Wykład 15: Rozproszone bazy danych

Podstawy języka SQL. SQL Structured Query Languagestrukturalny

Oracle PL/SQL. Paweł Rajba.

Wykład 5. SQL praca z tabelami 2

CHEATSHEET Administracja bazami danych Oracle I Start i wyłączanie instancji

Język zapytań SQL- język relacyjnych baz danych

Transkrypt:

Zarządzanie obiektami bazy danych Oracle11g Wstęp Obiekty to struktury przechowujące, porządkujące lub operujące na danych takie jak: Tabele Więzy integralności Indeksy Widoki Sekwencje Procedury Linki bazodanowe itp. Do operowania na obiektach służą polecenia DDL (Data Definiotion Language), a do operacji na danych DML (Data Manipulation Language) do których należą między innymi polecenia Insert, Update, Delete, Merge. Tabele Tabele to podstawowe obiekty w bazie danych przechowujące dane w kolumach i wierszach. Do tworzenia tabel służy polecenie CREATE TABLE. W poleceniu tworzącym tabele można od razu zdefiniować: więzy integralności wskazać przestrzeń tabel stworzyć tabele na podstawie zapytania SQL tabele tymczasową Strona: 1 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7

Oto przykłady poleceń tworzących tabele: CREATE TABLE EMPLOYEES ( ID NUMBER(6) PRIMARY KEY, NAME VARCHAR2(50) NOT NULL, PESEL VARCHAR2(11), HIRE_DATE DATE NOT NULL, SALARY NUMBER (6,2), MANAGER_ID NUMBER(6), SEX CHAR(1) ) TABLESPACE USERS; Wraz z więzami integralności takimi jak PRIMARY KEY czy UNIQUE baza danych tworzy powiązane z nimi indeksy unikalne w celu wymuszenia unikalności wartości tych kolumn. Tabele użytkownika można odczytać w perspektywie USER_TABLES. Administrator bazy danych może odczytać tabele innych użytkowników w perspektywie DBA_TABLES. Kolumny tabel można odczytać odpowiednio: dla użytkownika w USER_TAB_COLUMNS, dla administratora perspektywie DBA_TAB_COLUMNS Tabele tymczasowe Tabela tymczasowa daje użytkownikowi możliwość przechowywania danych na czas trwania transakcji lub sesji. Po zakończeniu transakcji lub sesji dane są automatycznie usuwane. Operacje DML wykonywane na tabelach tymczasowych nie generują zmian w redo logach ponieważ nie ma potrzeby odtwarzania danych po ewentualnej awarii systemu. Zmiany na danych w tabelach tymczasowych nie generują również zmian w segmentach UNDO ponieważ nie ma potrzeby przywracania starych wartości w przypadku wycofania transakcji. Tak więc operacje DML na tabelach tymczasowych są szybsze niż w przypadku normalnych tabel. Tabele tymczasowe są często używane w procedurach PL/SQL do gromadzenia i wykonywania przetwarzania danych. Tabele tymczasowe tworzone są zawsze w tymczasowej przestrzeni tabel. Tabele tymczasowe tworzy się poleceniem: CREATE GLOBAL TEMPORARY TABLE TEMP_TABLE ( ID NUMBER(6) NAME VARCHAR2(200) ) ON COMMIT PRESERVE ROWS; Strona: 2 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7

Więzy integralności Więzy integralności to mechanizmy służące zapewnieniu spójności danych. Należą do nich: PRIMARY KEY klucz główny UNIQUE - unikalność FOREIGN KEY klucz obcy NOT NULL zawsze jakoś wartość CHECK sprawdzanie warunków Więzy integralności mogą być zakładane wraz z poleceniem tworzenia tabeli lub później za pomocą polecenia ALTER TABLE ADD CONSTRAINT. ALTER TABLE EMPLOYEES ADD CONSTRAINT MGR_FK FOREIGN KEY (MANAGER_ID) REFERENCES EMPLOYEES(ID); Więzy integralności NOT NULL realizowane są w bazie danych Oracle jako więzy typu CHECK np: ALTER TABLE EMPLOYEES ADD CONSTRAINT NAME_NOT_NULL CHECK (NAME IS NOT NULL); Więzy integralności mogą być sprawdzane natychmiast (IMMEDIATE) po wykonaniu polecenia DML lub sprawdzenie może zostać opóźnione (DEFERRED) do momentu zatwierdzania transakcji. ALTER TABLE EMPLOYEES ADD CONSTRAINT EMP_CHECK_SAL CHECK (SALARY>0) INITIALLY DEFERRED DEFERRABLE; ALTER TABLE EMPLOYEES ADD CONSTRAINT EMP_UNQ_PESEL UNIQUE (PESEL); Domyślnym trybem zakładania więzów integralności jest sprawdzanie natychmiastowe więc w przykładzie powyżej EMP_UNQ_PESEL będzie sprawdzany natychmiast po wykonaniu polecenia DML, a EMP_CHECK_SAL dopiero w momencie zatwierdzania transakcji. Tryb pracy więzów integralności można zmienić poleceniem ALTER TABLE MODIFY CONSTRAINIT np: alter table employees modify constraint emp_check_sal initially immediate; Dodatkowo, więzy integralności mogą być w jednym z czterech stanów: DISABLE NOVALIDATE tryb sprawdzania jest wyłączony czyli ani istniejące dane w tabeli ani nowe nie są sprawdzane. DISABLE VALIDATE istniejące dane w tabeli zostają sprawdzone, ale nowe dane nie są przyjmowane. W tym trybie nie da się wykonywać operacji DML na tabeli ENABLE NOVALIDATE istniejące dane w tabeli nie są sprawdzane, ale nowe przychodzące tak. ENABLE VALIDATE domyślny stan pracy kiedy zarówno istniejące jak i nowe dane są sprawdzane. Strona: 3 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7

Zmiany stanu pracy dokonuje się również poleceniem ALTER TABLE MODIFY CONSTRAINT np: ALTER TABLE EMPLOYEES MODIFY CONSTRAINT EMP_UNQ_PESEL DISABLE NOVALIDATE; ALTER TABLE EMPLOYEES MODIFY CONSTRAINT EMP_UNQ_PESEL DISABLE VALIDATE; ALTER TABLE EMPLOYEES MODIFY CONSTRAINT EMP_UNQ_PESEL ENABLE NOVALIDATE; ALTER TABLE EMPLOYEES MODIFY CONSTRAINT EMP_UNQ_PESEL ENABLE VALIDATE; Transakcje W bazie Oracle nie ma specjalnych instrukcji sterujących, które rozpoczynają nową transakcję. Każde polecenie DML czyli Insert, Update, Delete lub Merge wykonane po ostatnim poleceniu COMMIT lub ROLLBACK rozpoczyna niejawnie nową transakcję. Transakcja to atomowy zestaw instrukcji DML, które albo wszystkie wykonają się poprawnie i mogą zostać zatwierdzone poleceniem COMMIT, albo w przypadku wystąpienia błędu przy któreś operacji wszystkie pozostałe zostaną wycofane poleceniem ROLLBACK. INSERT INTO EMPLOYEES VALUES (1, JAN, 78060903083, SYSDATE, 5000); INSERT INTO EMPLOYEES VALUES (2, KAROL, 78060903084, SYSDATE, 6000); INSERT INTO EMPLOYEES VALUES (3, TOMASZ, 78060903085, SYSDATE, 3000); COMMIT; Dopóki transakcja nie zostanie zatwierdzona inne sesje nie widzą zmian wprowadzanych przez użytkownika. Dzięki temu zapewniona jest izolacja transakcji między sesjami. Baza danych zapewnia współbieżność operacji to znaczy, że wiele sesji może wykonywać operacje DML na tej samej tabeli pod warunkiem, że nie zmieniają tych samych rekordów. Podczas operacji DML zakładane są blokady na wierszach, które podlegają modyfikacji, a także na samej tabeli, aby podczas trwania transakcji inna sesja nie mogła zmodyfikować struktury tabeli lub jej usunąć. Transakcja 1 Użytkownik 1 Transakcja 2 Użytkownik 2 UPDATE EMPLOYEES SET SALARY = 2000 UPDATE EMPLOYEES SET SALARY = 2000 WHERE ID=100; WHERE ID=100; Operacja zawieszona bo transakcja nr 1 blokuje wiersz o id=100. COMMIT; Operacja UPDATE wykonuje sie dopiero kiedy transakcja nr 1 wykona zatwierdzanie lub wycofanie transakcji czyli COMMIT lub ROLLBACK. Strona: 4 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7

Inny przykład: Transakcja 1 Użytkownik 1 Transakcja 2 Użytkownik 2 UPDATE EMPLOYEES SET SALARY = 2000 ALTER TABLE EMPLOYYES ADD (COL1 WHERE ID=100; NUMBER); Operacja wstrzymana do momentu zatwierdzenia lub wycofania transakcji 1. COMMIT; Dopiero po wykonaniu operacji COMMIT w transakcji 1 wykona się dodanie kolumny w tabeli EMPLOYEES. Czasami zdarza się, że dwie transakcje będą próbować aktualizować te same rekordy, ale w odwrotnej kolejności i może dojść do zakleszczenia (DEADLOCK). Na przykład: Transakcja 1 Użytkownik 1 Transakcja 2 Użytkownik 2 UPDATE EMPLOYEES SET SALARY = 2000 UPDATE EMPLOYEES SET SALARY = 3000 WHERE ID=100; WHERE ID=200; UPDATE EMPLOYEES SET SALARY = 3000 UPDATE EMPLOYEES SET SALARY = 2000 WHERE ID=200; WHERE ID=100; ORA-00060: DEADLOCK DETECTED WHILE WAITING FOR RESOURCE Zakleszczenia czyli DEADLOCK są wykrywane i rozwiązywane przez samą bazę danych, a więc użytkownik nie musi się tym przejmować. W momencie zablokowania transakcji istniejącą na tabeli blokadą założoną przez inną transakcję, takie oczekiwanie może być bardzo długie bo nie mamy wpływu na operacje wykonywane w innej sesji. Stąd czasami jest potrzeba zabicia blokującej transakcji. Najpierw należy sprawdzić, która sesja blokuje a następnie wykonać polecenie ALTER SYSTEM KILL SESSION np: Transakcja 1 Użytkownik 1 Transakcja 2 Użytkownik 2 Transakcja 3 Użytkownik SYS UPDATE EMPLOYEES SET SALARY = 2000 WHERE ID=100; UPDATE EMPLOYEES SET SALARY = 2000 WHERE ID=100; Operacja wstrzymana do momentu zatwierdzenia lub wycofania transakcji 1. Transakcja przez długi czas nie zatwierdza ani nie wycofuje Użytkownik 2 zgłasza problem administratorowi SYS SELECT SID, SERIAL#, USERNAME FROM V$SESSION WHERE SID IN Strona: 5 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7

(SELECT BLOCKING_SESSION FROM V$SESSION) Nastąpiło rozłączenie i wycofanie całej transakcji 1. Wstrzymana operacja wykonuje się natychmiast po zabiciu sesji użytkownika 1 SID SERIAL# USERNAME 9 5 MIKE ALTER SYSTEM KILL SESSION 9,5 IMMEDIATE; Ćwiczenia Ćwiczenie nr 1 Tabele i więzy integralności Wszystkie polecenia wykonać w SQLPLUS z zachowaniem nazw obiektów 1. Utworzyć użytkownika HR i nadać mu role CONNECT i RESOURCE 2. Jako użytkownik HR utworzyć tabele EMPLOYEES z następującym zestawem kolumn: a. employee_id NUMBER(6) b. first_name VARCHAR2(20) c. last_name VARCHAR2(25) d. email VARCHAR2(25) e. salary NUMBER(8,2) f. manager_id NUMBER(6) 3. Dodać do tabeli EMPLOYEES następujące więzy integralności: a. Klucz główny na kolumnie employee_id b. Unikalność na kolumnach email oraz c. Klucz obcy odroczony (deferred) na kolumnie manager_id odnoszący się do tej samej tabeli i kolumny employee_id d. NOT NULL na kolumnach first_name i last_name e. CHECK na kolumnie salary z warunkiem salary > 0 4. Dodać do tabeli EMPLOYEES kilka wierszy i sprawdzić jak zachowują się więzy integralności sprawdzane natychmiast (IMMEDIATE) oraz te odroczone (DEFERRED). Które więzy integralności sprawdzane są w trakcie zatwierdzania transakcji, a które zaraz po wykonaniu polecenia DML? Czy w momencie naruszenia któregoś z więzów integralności wycofywane są wszystkie dotychczas dodane wiersze czy tylko ten błędny? 5. Przełączyć klucz obcy na tabeli EMPLOYEES w tryb DISABLE VALIDATE 6. Wprowadzić kilka nowych wierszy do tabeli EMPLOYEES. Czy się udało? Jeśli nie to dlaczego? 7. Przełączyć klucz obcy na tabeli EMPLOYEES w tryb DISABLE NOVALIDATE 8. Wprowadzić kilka nowych wierszy do tabeli EMPLOYEES z błędną wartością kolumny manager_id. Czy sie udało? Strona: 6 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7

9. Przełączyć klucz obcy na tabeli EMPLOYEES w tryb ENABLE NOVALIDATE 10. Wprowadzić kilka nowych wierszy do tabeli EMPLOYEES z błędną wartością kolumny manager_id. Czy tym razem się udało? 11. Przełączyć klucz obcy na tabeli EMPLOYEES w tryb ENABLE VALIDATE. Czy udało się przełączyć klucz obcy w ten tryb? Jeśli nie to zastanowić się co jest przyczyną i rozwiązać problem. Ćwiczenie 2 Tabele tymczasowe 1. Jako użytkownik HR utworzyć tabelę tymczasową EMPLOYEES_TEMP z taką samą strukturą kolumn jak w tabeli EMPLOYEES z usuwaniem wierszy przy zakończeniu sesji. 2. Załadować wiersze z tabeli EMPLOYEES do tabeli EMPLOYEES_TEMP 3. Sprawdzić czy po zakończeniu transakcji wiersze wciąż są w tabeli tymczasowej 4. W drugim terminalu SQLPLUS zalogować się jako ten sam użytkownik HR i sprawdzić zawartość tabeli EMPLOYEES_TEMP. Dlaczego nie ma żadnych wierszy mimo, że przed chwilą ładowane były z innego terminala? 5. Ćwiczenie 3 Transakcje 1. Otworzyć dwa terminale SQLPLUS i zalogować się jako ten sam użytkownik HR 2. W sesji pierwszej spróbować wykonać UPDATE na jakimś konkretnym wierszu nie zatwierdzając transakcji, a w drugiej spróbować usunąć ten sam wiersz. Wiersze najlepiej identyfikować po kluczu głównym. Co się dzieje w drugiej transakcji, czy usunięcie udało się wykonać od razu? 3. W sesji pierwszej zatwierdzić transakcję czyli operację UPDATE. Co się stało w drugiej sesji? 4. Powtórzyć punkt nr 2 tyle, że w drugiej sesji wykonać operację dodania nowej kolumny do tabeli. Czy dodanie nowej kolumny do tabeli jest blokowane przez UPDATE pojedynczego wiersza? Jeśli tak to dlaczego? 5. Powtórzyć punkt nr 2, z tą jednak różnicą polegającą na otworzeniu trzeciego terminala i podłączenia się do bazy jako SYS. Sprawdzić blokujące transakcje i jako zabić tę sesję która blokuje. Co się stanie w sesji oczekującej? 6. W dwóch sesjach doprowadzić do zakleszczenia (deadlock) transakcji. Czy baza sama umie poradzić sobie z taką sytuacją? Strona: 7 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7

Rozwiązania Zarządzanie obiektami bazy danych Oracle 11g Ćwiczenie 1 1. Utworzyć użytkownika HR i nadać mu role CONNECT i RESOURCE a. CREATE USER HR IDENTIFIED BY HR; b. GRANT CONNECT, RESOURCE TO HR; 2. Jako użytkownik HR utworzyć tabele EMPLOYEES CREATE TABLE EMPLOYEES ( EMPLOYEE_ID NUMBER(6), FIRST_NAME VARCHAR2(20), LAST_NAME VARCHAR2(25), EMAIL VARCHAR2(25), SALARY NUMBER(8,2), MANAGER_ID NUMBER(6) ) ; 3. Dodać do tabeli EMPLOYEES następujące więzy integralności: a. Klucz główny na kolumnie employee_id i. ALTER TABLE EMPLOYEES ADD CONSTRAINT EMP_PK PRIMARY KEY (EMPLOYEE_ID); b. Unikalność na kolumnach email i. ALTER TABLE EMPLOYEES ADD CONSTRAINT EMP_UNIQUE_EMAIL UNIQUE (EMAIL); c. Klucz obcy odroczony (deferred) na kolumnie manager_id odnoszący się do tej samej tabeli i kolumny employee_id i. ALTER TABLE EMPLOYEES ADD CONSTRAINT EMP_MANAGER_FK FOREIGN KEY (MANAGER_ID) REFERENCES EMPLOYEES (EMPLOYEE_ID) INITIALLY DEFERRED DEFERRABLE; d. NOT NULL na kolumnach first_name i last_name ALTER TABLE EMPLOYEES ADD CONSTRAINT F_NAME_NN CHECK (FIRST_NAME IS NOT NULL); ALTER TABLE EMPLOYEES ADD CONSTRAINT L_NAME_NN CHECK (LAST_NAME IS NOT NULL); e. CHECK na kolumnie salary z warunkiem salary > 0 i. ALTER TABLE EMPLOYEES ADD CONSTRAINT SAL_POSITIVE CHECK (SALARY > 0); 4. Dodać do tabeli EMPLOYEES kilka wierszy i sprawdzić jak zachowują się więzy integralności sprawdzane natychmiast (IMMEDIATE) oraz te odroczone (DEFERRED). Które więzy integralności Strona: 8 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7

sprawdzane są w trakcie zatwierdzania transakcji, a które zaraz po wykonaniu polecenia DML? Czy w momencie naruszenia któregoś z więzów integralności wycofywane są wszystkie dotychczas dodane wiersze czy tylko ten błędny? a. INSERT INTO EMPLOYEES VALUES( 1000, 'STEVEN 0', 'KING 0', 'SKING0@COMPANY.COM',24000, NULL); b. INSERT INTO EMPLOYEES VALUES( 1000, 'STEVEN 0', 'KING 0', 'SKING0@COMPANY.COM',24000, NULL ); c. INSERT INTO EMPLOYEES VALUES( 1001, 'STEVEN 1', 'KING 1', 'SKING1@COMPANY.COM', 24010, 2000); d. COMMIT; e. Więzy natychmiastowe sa sprawdzane zaraz po wykonaniu polecenia DML. Jeśli wynik jest negatywny tylko ta pojedyncza operacja zostaje wycofana. Pozostałe operacje w transakcji są nadal aktualne. f. Więzy odroczone są sprawdzane dopiero w momencie zatwierdzania transakcji. Jeśli wynik jest negatywny na choć jednym wierszu to cała transakcja jest wycofywana. 5. Przełączyć klucz obcy na tabeli EMPLOYEES w tryb DISABLE VALIDATE a. ALTER TABLE EMPLOYEES MODIFY CONSTRAINT EMP_MANAGER_FK DISABLE VALIDATE; 6. Wprowadzić kilka nowych wierszy do tabeli EMPLOYEES. Czy się udało? Jeśli nie to dlaczego? a. INSERT INTO EMPLOYEES VALUES( 1004, 'STEVEN 4', 'KING 4', 'SKING4@COMPANY.COM',24040, NULL ); b. ORA-25128: WSTAWIANIE/AKTUALIZACJA/USUWANIE W TABELI Z WIĘZAMI (HR.EMP_MANAGER_FK) JEST WYŁĄCZONE I SPRAWDZONE 7. Przełączyć klucz obcy na tabeli EMPLOYEES w tryb DISABLE NOVALIDATE a. ALTER TABLE EMPLOYEES MODIFY CONSTRAINT EMP_MANAGER_FK DISABLE NOVALIDATE; 8. Wprowadzić kilka nowych wierszy do tabeli EMPLOYEES z nieistniejącym identyfikatorem do kolumny manager_id a. INSERT INTO EMPLOYEES VALUES( 1005, 'STEVEN 5', 'KING 5', 'SKING5@COMPANY.COM', 24050, -1); b. INSERT INTO EMPLOYEES VALUES( 1006, 'STEVEN 6', 'KING 6', 'SKING6@COMPANY.COM', 24060, -2); c. COMMIT; 9. Przełączyć klucz obcy na tabeli EMPLOYEES w tryb ENABLE NOVALIDATE a. ALTER TABLE EMPLOYEES MODIFY CONSTRAINT EMP_MANAGER_FK ENABLE NOVALIDATE; 10. Wprowadzić kilka nowych wierszy do tabeli EMPLOYEES. Czy tym razem klucy obcz jest weryfikowany? Comment [m1]: Błędna wartość. Ten sam klucz co w operacji powyżej. Sprawdzam walidację klucza głównego Comment [m2]: Błędna wartość. Ta sama wartość jak kolumnie powyżej. Sprawdzam walidację unikalności Comment [m3]: Błędna wartość klucza obcego. Sprawdzam jak zachowuje się walidacja odroczona. Comment [m4]: Błędna wartość klucza obcego Comment [m5]: Błędna wartość klucza obcego A. INSERT INTO EMPLOYEES VALUES( 1007, 'STEVEN 7', 'KING 7', 'SKING7@COMPANY.COM',24070, 1006 ); Strona: 9 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7

b. INSERT INTO EMPLOYEES VALUES( 1008, 'STEVEN 8', 'KING 8', 'SKING8@COMPANY.COM',24080, 1007 ); c. COMMIT; d. Tym razem klucz obcy jest walidowany poprawnie. 11. Przełączyć klucz obcy na tabeli EMPLOYEES w tryb ENABLE VALIDATE. Czy udało się przełączyć klucz główny w ten tryb? Jeśli nie to zastanowić się co jest przyczyną i rozwiązać problem. a. ALTER TABLE EMPLOYEES MODIFY CONSTRAINT EMP_MANAGER_FK ENABLE VALIDATE; b. Może się nie udać bo w tabeli są błędne wiersze nieodpowiadające. Nalezy usunąć błędne wiersze lub je zaktualizowć. Ćwiczenie 2 Tabele tymczasowe 1. Jako użytkownik HR utworzyć tabelę tymczasową EMPLOYEES_TEMP z taką samą strukturą kolumn jak w tabeli EMPLOYEES z usuwaniem wierszy przy zakończeniu sesji. a. CREATE GLOBAL TEMPORARY TABLE EMPLOYEES_TEMP ON COMMIT PRESERVE ROWS AS SELECT * FROM EMPLOYEES WHERE 1=2; 2. Załadować wiersze z tabeli EMPLOYEES do tabeli EMPLOYEES_TEMP a. INSERT INTO EMPLOYEES_TEMP (SELECT * FROM EMPLOYEES); b. COMMIT; 3. Sprawdzić czy po zakończeniu transakcji wiersze wciąż są w tabeli tymczasowej a. SELECT * FROM EMPLOYEES_TEMP; b. wiersze wciąż są w tabeli tymczasowej 4. W drugim terminalu SQLPLUS zalogować się jako ten sam użytkownik HR i sprawdzić zawartość tabeli EMPLOYEES_TEMP. Dlaczego nie ma żadnych wierszy mimo, że przed chwilą ładowane były z innego terminala? a. Nie widać bo wiersze w tabelach tymczasowych są dostępne tylko w tej sesji które je wprowadziła. Ćwiczenie 3 Transakcje Operacje wymagane do zrobienia tego ćwiczenia nie wymagają podawania rozwiązania ponieważ głównie bazują na prostych instrukcjach UPDATE. Strona: 10 Administracja bazą Oracle 11g Studia Podyplomowe SGGW Laboratorium nr 7