Zarządzanie obiektami bazy danych Oracle11g

Wielkość: px
Rozpocząć pokaz od strony:

Download "Zarządzanie obiektami bazy danych Oracle11g"

Transkrypt

1 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

2 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

3 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

4 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, , SYSDATE, 5000); INSERT INTO EMPLOYEES VALUES (2, KAROL, , SYSDATE, 6000); INSERT INTO EMPLOYEES VALUES (3, TOMASZ, , 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

5 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

6 (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. 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 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

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

8 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), 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 i. ALTER TABLE EMPLOYEES ADD CONSTRAINT EMP_UNIQUE_ UNIQUE ( ); 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

9 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

10 b. INSERT INTO EMPLOYEES VALUES( 1008, 'STEVEN 8', 'KING 8', 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

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

3 Przygotowali: mgr inż. Barbara Łukawska, mgr inż. Maciej Lasota Laboratorium nr 3 1 Bazy Danych Instrukcja laboratoryjna Temat: Wprowadzenie do języka SQL, tworzenie, modyfikacja, wypełnianie tabel 3 Przygotowali: mgr inż. Barbara Łukawska, mgr inż. Maciej Lasota 1)

Bardziej szczegółowo

Bazy danych - Materiały do laboratoriów VIII

Bazy danych - Materiały do laboratoriów VIII Bazy danych - Materiały do laboratoriów VIII dr inż. Olga Siedlecka-Lamch Instytut Informatyki Teoretycznej i Stosowanej Politechnika Częstochowska 23 kwietnia 2011 roku Polecenie COMMIT i ROLLBACK Polecenie

Bardziej szczegółowo

Wykład 8. SQL praca z tabelami 5

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

Bardziej szczegółowo

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

Zbiór pytań nr 2. 1 Tabela DEPARTMENTS ma następującą strukturę: Zbiór pytań nr 2 1 Tabela DEPARTMENTS ma następującą strukturę: Nazwa kolumny Typ danych Uwagi dept_id NUMBER(4) NOT NULL, PRIMARY KEY dept_name VARCHAR2(30) mgr_id NUMBER(6) location_id NUMBER(4) Które

Bardziej szczegółowo

Zarządzanie obiektami bazy danych Oracle11g

Zarządzanie obiektami bazy danych Oracle11g Zarządzanie obiektami bazy danych Oracle11g Wstęp Kontynuując ćwiczenia dotyczące obiektów w bazie Oracle, na dzisiejszych zajęciach zajmiemy sie: Indeksami Technologią Flashback Indeksy Indeksy to struktury,

Bardziej szczegółowo

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

I. Język manipulowania danymi - DML (Data Manipulation Language). Polecenia INSERT, UPDATE, DELETE Wykład 9 Implementacja języka SQL w systemach baz danych Oracle manipulowanie danymi (DML), tworzenie, modyfikowanie i usuwanie obiektów bazy danych: tabel i perspektyw, więzów integralności, komentarzy

Bardziej szczegółowo

Autor: Joanna Karwowska

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ę,

Bardziej szczegółowo

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

UPDATE Studenci SET Rok = Rok + 1 WHERE Rodzaj_studiow =' INŻ_ST'; UPDATE Studenci SET Rok = Rok 1 WHERE Nr_albumu IN ( '111345','100678'); polecenie UPDATE służy do aktualizacji zawartości wierszy tabel lub perspektyw składnia: UPDATE { } SET { { = DEFAULT NULL}, {

Bardziej szczegółowo

Bazy danych 9. SQL Klucze obce Transakcje

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

Bardziej szczegółowo

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

startup pfile= '$HOME/admin/pfile/initDBx.ora'; create spfile from pfile= '$HOME/admin/pfile/initDBx.ora'; Administrowanie systemami baz danych Ćwiczenia laboratoryjne (1) Podstawy uruchamiania serwera bazy danych 1. Przy pomocy programu Putty, połącz się z serwerem miner.cs.put.poznan.pl. Dla wygody otwórz

Bardziej szczegółowo

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

Język SQL. Rozdział 9. Język definiowania danych DDL, część 2. Język SQL. Rozdział 9. Język definiowania danych DDL, część 2. Ograniczenia integralnościowe, modyfikowanie struktury relacji, zarządzanie ograniczeniami. 1 Ograniczenia integralnościowe Służą do weryfikacji

Bardziej szczegółowo

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

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

Bardziej szczegółowo

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

Instrukcja podwaja zarobki osób, których imiona zaczynają się P i dalsze litery alfabetu zakładamy, że takich osbób jest kilkanaście. Rodzaje triggerów Triggery DML na tabelach INSERT, UPDATE, DELETE Triggery na widokach INSTEAD OF Triggery DDL CREATE, ALTER, DROP Triggery na bazie danych SERVERERROR, LOGON, LOGOFF, STARTUP, SHUTDOWN

Bardziej szczegółowo

Język SQL, zajęcia nr 1

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

Bardziej szczegółowo

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

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

Bardziej szczegółowo

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

Bazy danych wykład szósty Więzy i wyzwalacze. Konrad Zdanowski ( Uniwersytet Kardynała Stefana Bazy danych Wyszyńskiego, wykładwarszawa) Bazy danych wykład szósty Więzy i wyzwalacze Konrad Zdanowski Uniwersytet Kardynała Stefana Wyszyńskiego, Warszawa szósty Więzy i wyzwalacze 1 / 35 Wstęp Wiemy jak nakładać pewne ograniczenia (więzy) w

Bardziej szczegółowo

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

Rozdział 17. Zarządzanie współbieżnością zadania dodatkowe Rozdział 17. Zarządzanie współbieżnością zadania dodatkowe -- Definicje relacji i utworzenie stanu początkowego dla ćwiczeń z synchronizacji transakcji DROP TABLE Konta cascade constraints; DROP TABLE

Bardziej szczegółowo

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

1 Zaznacz poprawne stwierdzenia dotyczące grup plików (filegroup) możemy określić do której grupy plików trafi 1 Zaznacz poprawne stwierdzenia dotyczące grup plików (filegroup) Tworząc tabelę nie możemy określić, do którego pliku trafi, lecz możemy określić do której grupy plików trafi Zawsze istnieje grupa zawierająca

Bardziej szczegółowo

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

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:

Bardziej szczegółowo

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

Tworzenie tabeli przez select CREATE TABLE PRAC2 AS SELECT P.NAZWISKO, Z.NAZWA FROM PRAC P NATURAL JOIN ZESP Z Tworzenie tabeli Np. create table nazwa_tab( \\stworzenie tabeli Id numer(4) constraint PRAC_PK primary key, \\ustawiamy klucz podst. Nazwisko varchar2(30), \\typ tekstowy 30 znaków Kwota number(10,2)

Bardziej szczegółowo

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 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

Bardziej szczegółowo

Wprowadzenie do projektowania i wykorzystania baz danych Relacje

Wprowadzenie do projektowania i wykorzystania baz danych Relacje Wprowadzenie do projektowania i wykorzystania baz danych Relacje Katarzyna Klessa Dygresja nt. operatorów SELECT 2^2 SELECT 2^30 SELECT 50^50 2 Dygresja nt. operatorów SELECT 2^30 --Bitwise exclusive OR

Bardziej szczegółowo

Zarządzanie strukturą bazy danych Oracle11g

Zarządzanie strukturą bazy danych Oracle11g Zarządzanie strukturą bazy danych Oracle11g Wstęp Baza danych Oracle przechowuje dane użytkowników oraz własne dane słownikowe w następujących strukturach logicznych: przestrzenie tabel segmenty extenty

Bardziej szczegółowo

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

SQL DDL DML TECHNOLOGIE BAZ DANYCH. Wykład 5: Język DDL i DML. Małgorzata Krętowska SQL TECHNOLOGIE BAZ DANYCH Wykład 5: Język DDL i DML. SQL (ang. StructuredQueryLanguage) strukturalny język zapytań używany do tworzenia, modyfikowania relacyjnych baz danych oraz do umieszczania i pobierania

Bardziej szczegółowo

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

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

Bardziej szczegółowo

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

Ustawienie na poziomie sesji (działa do zmiany lub zakończenia sesji zamknięcia połączenia). POZIOMY IZOLACJI TRANSAKCJI 1. Microsoft SQL Server 2012 (od SQL Server 2005) W systemie SQL Server można wybrać sposób sterowania współbieżnością. Podstawowy sposób to stosowanie blokad. Wykorzystywane

Bardziej szczegółowo

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

Rozdział 17. Zarządzanie współbieżnością zadania Rozdział 17. Zarządzanie współbieżnością zadania Transakcja DML 1. Uruchom narzędzie Oracle SQL Developer i przyłącz się do bazy danych. Następnie rozpocznij nową transakcję, zmieniając pracownikowi o

Bardziej szczegółowo

Pawel@Kasprowski.pl Bazy danych. Bazy danych. Podstawy języka SQL. Dr inż. Paweł Kasprowski. pawel@kasprowski.pl

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ść

Bardziej szczegółowo

Bazy danych 9. Klucze obce Transakcje

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

Bardziej szczegółowo

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

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

Bardziej szczegółowo

Uprawnienia, role, synonimy

Uprawnienia, role, synonimy Uprawnienia, role, synonimy Schemat, użytkownicy, autoryzacja użytkowników, uprawnienia systemowe i obiektowe, nadawanie i odbieranie uprawnień, tworzenie ról, przywileje, synonimy Schematy i użytkownicy

Bardziej szczegółowo

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

Wyzwalacze. do automatycznego generowania wartości kluczy głównych. Składnia instrukcji tworzacej wyzwalacz Wyzwalacze Wyzwalacze są specjalnymi procedurami składowanymi, uruchamianymi automatycznie w następstwie zaistnienia określonego typu zdarzenia. Ich główne zadanie polega na wymuszaniu integralności danych

Bardziej szczegółowo

Tworzenie tabel. Bazy danych - laboratorium, Hanna Kleban 1

Tworzenie tabel. Bazy danych - laboratorium, Hanna Kleban 1 Tworzenie tabel Tabela podstawowa struktura, na której zbudowana jest relacyjna baza danych. Jest to zbiór kolumn (atrybutów) o ustalonych właściwościach, w których przechowuje się dane. Dane te są reprezentowane

Bardziej szczegółowo

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

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

Bardziej szczegółowo

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

Wykład V. Indeksy. Struktura indeksu składa się z rekordów o dwóch polach Indeksy dodatkowe struktury służące przyśpieszeniu dostępu do danych o użyciu indeksu podczas realizacji poleceń decyduje SZBD niektóre systemy bazodanowe automatycznie tworzą indeksy dla kolumn o wartościach

Bardziej szczegółowo

Projektowanie systemów baz danych

Projektowanie systemów baz danych Projektowanie systemów baz danych Seweryn Dobrzelewski 4. Projektowanie DBMS 1 SQL SQL (ang. Structured Query Language) Język SQL jest strukturalnym językiem zapewniającym możliwość wydawania poleceń do

Bardziej szczegółowo

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

Bazy danych wykład dziewiaty Transakcje. Konrad Zdanowski ( Uniwersytet Kardynała Stefana Bazy danych Wyszyńskiego, wykładwarszawa) Bazy danych wykład dziewiaty Transakcje Konrad Zdanowski Uniwersytet Kardynała Stefana Wyszyńskiego, Warszawa dziewiaty Transakcje 1 / 42 Outline 1 Transakcje Problemy interakcji 2 Metody usuwania konfliktów

Bardziej szczegółowo

Cwiczenie 7. Retrospekcja

Cwiczenie 7. Retrospekcja Cwiczenie 7. Retrospekcja 1. Sprawdzenie środowiska Czas trwania: 15 minut Mechanizmy związane z retrospekcją wymagają spełnienia kilku warunków. W pierwszym ćwiczeniu dokonamy ich weryfikacji. Zakłada

Bardziej szczegółowo

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

1 Przetwarzanie transakcyjne Cechy transakcji Rozpoczęcie i zakończenie Punkty bezpieczeństwa... 3 Plan wykładu Spis treści 1 Przetwarzanie transakcyjne 1 1.1 Cechy transakcji................................. 2 1.2 Rozpoczęcie i zakończenie........................... 3 1.3 Punkty bezpieczeństwa.............................

Bardziej szczegółowo

Pakiety podprogramów Dynamiczny SQL

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)

Bardziej szczegółowo

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

Zbiór pytań nr 5. 2 Które stwierdzenie opisuje najlepiej zbiór uprawnień dostępny po wykonaniu Zbiór pytań nr 5 1 Które stwierdzenie opisuje najlepiej zbiór uprawnień dostępny po wykonaniu connect athos/musketeer grant select,insert,update,delete on athos.services to porthos with grant option; grant

Bardziej szczegółowo

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

Plan ćwiczenia. Rozdział 17. zarządzania współbieżnością. Dostęp współbieżny a dostęp spójny. Spójność bazy danych Plan ćwiczenia Rozdział 17 Zarządzanie współbieżnością Definicja i własności transakcji, zatwierdzanie i wycofywanie, punkty bezpieczeństwa, spójność, anomalie współbieżnego dostępu do danych, poziomy

Bardziej szczegółowo

Paweł Rajba pawel@ii.uni.wroc.pl http://www.itcourses.eu/

Paweł Rajba pawel@ii.uni.wroc.pl http://www.itcourses.eu/ Paweł Rajba pawel@ii.uni.wroc.pl http://www.itcourses.eu/ Wprowadzenie Historia i standardy Podstawy relacyjności Typy danych DDL tabele, widoki, sekwencje zmiana struktury DML DQL Podstawy, złączenia,

Bardziej szczegółowo

Aspekty aktywne baz danych

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ć

Bardziej szczegółowo

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

1 Projekt fizyczny 1. 3 Perspektywy słownika danych Źródła 12 Plan wykładu Spis treści 1 Projekt fizyczny 1 2 Transformacja ML do PF 2 2.1 Definiowanie tabel............................... 2 2.2 Więzy integralności............................... 4 2.3 Modyfikacja

Bardziej szczegółowo

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

Server Oracle - System Zarządzania Bazą Danych - składa się z instancji Oracle i bazy danych Oracle Instancja Oracle - pewne procesy drugoplanowe i Server Oracle - System Zarządzania Bazą Danych - składa się z instancji Oracle i bazy danych Oracle Instancja Oracle - pewne procesy drugoplanowe i struktury pamięciowe - aby użytkownik mógł uzyskać dostęp

Bardziej szczegółowo

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

przykłady problemów; realizacja dostaw części od producenta do klienta: Przetwarzanie transakcyjne Transakcja zestaw operacji pod szczególną kontrolą transakcja to sekwencja operacji, która musi zakończyć się sukcesem w całości - w przeciwnym wypadku musi powrócić stan początkowy

Bardziej szczegółowo

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

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

Bardziej szczegółowo

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

kończy wysyłanie danych do pliku tworzy strukturę tabeli wyświetla opis struktury tabeli zmiana nazwy tabeli usuwanie tabeli SPOOL moj_plik SPOOL OFF @ moj_ plik edit CREATE TABLE DESCRIBE ALTER TABLE RENAME DROP TABLE CONNECT CONNECT USER_NAME DISCONNECT EXIT zapisuje wszystkie wydane polecenia oraz ich wyniki do pliku moj_plik,

Bardziej szczegółowo

Wykład 05 Bazy danych

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

Bardziej szczegółowo

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 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

Bardziej szczegółowo

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

P o d s t a w y j ę z y k a S Q L P o d s t a w y j ę z y k a S Q L Adam Cakudis IFP UAM Użytkownicy System informatyczny Aplikacja Aplikacja Aplikacja System bazy danych System zarządzania baz ą danych Schemat Baza danych K o n c e p

Bardziej szczegółowo

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

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

Bardziej szczegółowo

Oracle11g: Wprowadzenie do SQL

Oracle11g: Wprowadzenie do SQL Oracle11g: Wprowadzenie do SQL OPIS: Kurs ten oferuje uczestnikom wprowadzenie do technologii bazy Oracle11g, koncepcji bazy relacyjnej i efektywnego języka programowania o nazwie SQL. Kurs dostarczy twórcom

Bardziej szczegółowo

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

Integralność danych Wersje języka SQL Klauzula SELECT i JOIN Integralność danych Wersje języka SQL Klauzula SELECT i JOIN Robert A. Kłopotek r.klopotek@uksw.edu.pl Wydział Matematyczno-Przyrodniczy. Szkoła Nauk Ścisłych, UKSW Integralność danych Aspekty integralności

Bardziej szczegółowo

Zarzadzanie transakcjami. Transakcje

Zarzadzanie transakcjami. Transakcje Transakcje Transakcja: ciąg zawierający jedno lub wiele poleceń SQL, zgrupowanych razem jako jedna logiczna jednostka działań, której nie można podzielić. Logiczna jednostka działań to zbiór logicznych

Bardziej szczegółowo

PRZESTRZENNE BAZY DANYCH WYKŁAD 2

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

Bardziej szczegółowo

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

Plan ćwiczenia. Rozdział 17 Zarządzanie współbieżnością. Dostęp współbieżny a dostęp spójny. Spójność bazy danych Plan ćwiczenia Rozdział 17 Zarządzanie współbieżnością Definicja i własności transakcji, zatwierdzanie i wycofywanie, punkty bezpieczeństwa, spójność, anomalie współbieżnego dostępu do danych, poziomy

Bardziej szczegółowo

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

D D L S Q L. Co to jest DDL SQL i jakie s jego ą podstawowe polecenia? D D L S Q L Co to jest DDL SQL i jakie s jego ą podstawowe polecenia? D D L S Q L - p o d s t a w y DDL SQL (Data Definition Language) Jest to zbiór instrukcji i definicji danych, którym posługujemy się

Bardziej szczegółowo

Ćwiczenia laboratoryjne nr 11 Bazy danych i SQL.

Ć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

Bardziej szczegółowo

Przykładowa baza danych BIBLIOTEKA

Przykładowa baza danych BIBLIOTEKA Przykładowa baza danych BIBLIOTEKA 1. Opis problemu W ramach zajęć zostanie przedstawiony przykład prezentujący prosty system biblioteczny. System zawiera informację o czytelnikach oraz książkach dostępnych

Bardziej szczegółowo

Bazy danych. Dr inż. Paweł Kasprowski

Bazy danych. Dr inż. Paweł Kasprowski Plan wykładu Bazy danych Podstawy relacyjnego modelu danych Dr inż. Paweł Kasprowski pawel@kasprowski.pl Relacyjne bazy danych Język SQL Zapytania SQL (polecenie select) Bezpieczeństwo danych Integralność

Bardziej szczegółowo

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

SQL w języku PL/SQL. 2) Instrukcje języka definicji danych DDL DROP, CREATE, ALTER, GRANT, REVOKE Instrukcje SQL dzielimy na następujące kategorie: 1) Instrukcje języka manipulowania danymi (DML) SELECT, INSERT, UPDATE, DELETE, SET TRANSACTION, EXPLAIN PLAN 2) Instrukcje języka definicji danych DDL

Bardziej szczegółowo

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

Język SQL. Rozdział 9. Język definiowania danych DDL, część 2. zadania Język SQL. Rozdział 9. Język definiowania danych DDL, część 2. zadania 1. Zmodyfikuj strukturę relacji PROJEKTY, dodając do niej definicje następujących ograniczeń integralnościowych (użyj kilku poleceń):

Bardziej szczegółowo

DECLARE VARIABLE zmienna1 typ danych; BEGIN

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.;

Bardziej szczegółowo

Widok Connections po utworzeniu połączenia. Obszar roboczy

Widok Connections po utworzeniu połączenia. Obszar roboczy Środowisko pracy 1. Baza danych: Oracle 12c - Serwer ELARA - Konta studenckie, dostęp także spoza uczelni - Konfiguracja: https://e.piotrowska.po.opole.pl/index.php?option=conf 2. Środowisko: SQL Developer

Bardziej szczegółowo

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. 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

Bardziej szczegółowo

Internetowe bazy danych

Internetowe bazy danych Wyższa Szkoła Technologii Teleinformatycznych w Świdnicy Internetowe bazy danych wykład 3 dr inż. Jacek Mazurkiewicz e-mail: Jacek.Mazurkiewicz@pwr.wroc.pl Typy tabel MySQL domyślny MyISAM inne możliwe:

Bardziej szczegółowo

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

SELECT * FROM tabela WHERE warunek wybiera dane spełniające podany warunek SELECT SELECT kolumna1, kolumna2,, kolumnan FROM tabela wybrane kolumny SELECT * FROM tabela wszystkie kolumny select * from Orders select CustomerID, CompanyName, Country from Customers WHERE SELECT *

Bardziej szczegółowo

Przygotowanie bazy do wykonywania kopii bezpieczeństwa

Przygotowanie bazy do wykonywania kopii bezpieczeństwa Przygotowanie bazy do wykonywania kopii bezpieczeństwa Wstęp Wykonywanie kopii bezpieczeństwa i odtwarzanie po awarii jest jednym z kluczowych zadań administratora bazy danych. W momencie wystąpienia awarii

Bardziej szczegółowo

SQL :: Data Definition Language

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

Bardziej szczegółowo

Pawel@Kasprowski.pl Bazy danych. Bazy danych. Zapytania SELECT. Dr inż. Paweł Kasprowski. pawel@kasprowski.pl

Pawel@Kasprowski.pl Bazy danych. Bazy danych. Zapytania SELECT. Dr inż. Paweł Kasprowski. pawel@kasprowski.pl Bazy danych Zapytania SELECT Dr inż. Paweł Kasprowski pawel@kasprowski.pl Przykład HAVING Podaj liczebność zespołów dla których najstarszy pracownik urodził się po 1940 select idz, count(*) from prac p

Bardziej szczegółowo

Bazy danych Ćwiczenia projektowe

Bazy danych Ćwiczenia projektowe Bazy danych Ćwiczenia projektowe Przygotował: Piotr Hajder Katedra Informatyki Stosowanej i Modelowania Wydział Inżynierii Metali i Informatyki Przemysłowej, AGH Agenda 01. Powtórka 02. Interfejs CRUD

Bardziej szczegółowo

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

SQL> startup pfile=./admin/pfile/initdbx.ora. SQL> create spfile from pfile='$home/admin/pfile/initdbx.ora' create user bolek identified by bolek; Administrowanie użytkownikami Ćwiczenia laboratoryjne (2) Przygotowanie środowiska 1. Przy pomocy programu Putty, połącz się z serwerem miner.cs.put.poznan.pl. Dla wygody otwórz dwie sesje w dwóch różnych

Bardziej szczegółowo

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

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

Bardziej szczegółowo

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

Ile rekordów będzie zawierała tabela przy założeniu, że na początku była pusta? Gr Masyla: 1. Zaznacz poprawne stwierdzenia dotyczące opcji recovery model w MS SQL Server a) Ustawienie Simple pozwala zaoszczędzid miejsce na dysku b) Model full jest zalecany dla baz danych, w których

Bardziej szczegółowo

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

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ż

Bardziej szczegółowo

Transakcje. (c) Instytut Informatyki Politechniki Poznańskiej

Transakcje. (c) Instytut Informatyki Politechniki Poznańskiej ransakcje Definicja i własności transakcji, zatwierdzanie i wycofywanie, punkty bezpieczeństwa, spójność, anomalie współbieżnego dostępu do danych, poziomy izolacji transakcji, blokady, zakleszczenie Definicja

Bardziej szczegółowo

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

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

Bardziej szczegółowo

Bazy Danych II. Ćwiczenia

Bazy Danych II. Ćwiczenia Bazy Danych II. Ćwiczenia Bartosz Zieliński 16 kwietnia 2011 Spis treści 1 Powtórzenie SQL 3 1.1 Tworzenie i usuwanie tabel........................ 3 1.2 Wstawianie danych do tabel........................

Bardziej szczegółowo

1. Wyzwalacze BD (ang. triggers)

1. Wyzwalacze BD (ang. triggers) 1. Wyzwalacze BD (ang. triggers) Wyzwalacz bazy danych jest procedurą składowaną w bazie powiązaną z jedną konkretną tablicą. Z pojedynczą tablicą może być związane wiele wyzwalaczy, natomiast pojedynczy

Bardziej szczegółowo

Bazy danych 10. SQL Widoki

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

Bardziej szczegółowo

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

PL/SQL. Zaawansowane tematy PL/SQL. Piotr Medoń PL/SQL Zaawansowane tematy PL/SQL Piotr Medoń Cele Omówienie transakcji bazodanowych Omówienie obsługi wyjątków Zarządzanie perspektywami Tworzenie i usuwanie sekwencji Budowa wyzwalaczy 2 Transakcje bazodanowe

Bardziej szczegółowo

Oracle PL/SQL. Paweł Rajba.

Oracle PL/SQL. Paweł Rajba. Paweł Rajba pawel@ii.uni.wroc.pl http://www.kursy24.eu/ Zawartość modułu 7 Dynamiczny SQL i PL/SQL Pierwotny dynamiczny SQL Pierwotny dynamiczny DDL Pierwotny dynamiczny DML i SELECT Pakiet DBMS_SQL Transakcje

Bardziej szczegółowo

Obiekty bazy danych DB2

Obiekty bazy danych DB2 Obiekty bazy danych DB2 Obiektem bazy danych DB2 jest każdy składnik bazy danych DB2, jak: schematy, tabele, widoki, indeksy, sekwencje, aliasy, wyzwalacze, funkcje użytkownika (UDF-y), procedury zapamiętane,

Bardziej szczegółowo

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

Bazy danych Język SQL część 1 Wykład dla studentów matem Bazy danych Język SQL część 1 Wykład dla studentów matematyki 15 marca 2015 SQL Język wysokiego poziomu do komunikacji z bazami danych (ściślej: z systemami zarzadzania bazami danych) Podajemy co ma być

Bardziej szczegółowo

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

77. Modelowanie bazy danych rodzaje połączeń relacyjnych, pojęcie klucza obcego. 77. Modelowanie bazy danych rodzaje połączeń relacyjnych, pojęcie klucza obcego. Przy modelowaniu bazy danych możemy wyróżnić następujące typy połączeń relacyjnych: jeden do wielu, jeden do jednego, wiele

Bardziej szczegółowo

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

2010-11-22 PLAN WYKŁADU BAZY DANYCH PODSTAWOWE KWESTIE BEZPIECZEŃSTWA OGRANICZENIA DOSTĘPU DO DANYCH PLAN WYKŁADU Bezpieczeństwo w języku SQL Użytkownicy Uprawnienia Role BAZY DANYCH Wykład 8 dr inż. Agnieszka Bołtuć OGRANICZENIA DOSTĘPU DO DANYCH Ograniczenie danych z tabeli dla określonego użytkownika

Bardziej szczegółowo

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

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 cur.executescript(""" DROP TABLE IF EXISTS uczen; CREATE TABLE IF NOT EXISTS uczen ( Uniwersytet Technologiczno-Przyrodniczy im. J.J. Śniadeckich w Bydgoszczy Instrukcja do ćwiczeń laboratoryjnych Przedmiot

Bardziej szczegółowo

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

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

Bardziej szczegółowo

Zarządzanie użytkownikami bazy danych Oracle11g

Zarządzanie użytkownikami bazy danych Oracle11g Zarządzanie użytkownikami bazy danych Oracle11g Wstęp Baza danych Oracle jest systemem do którego może podłączyć się wielu użytkowników równoległych w tym samym czasie. Tożsamością i uprawnieniami zarządza

Bardziej szczegółowo

Bazy danych. Polecenia SQL

Bazy danych. Polecenia SQL Bazy danych Baza danych, to miejsce przechowywania danych. Dane w bazie danych są podzielone na tabele. Tabele składają się ze ściśle określonych pól i rekordów. Każde pole w rekordzie ma ściśle ustalony

Bardziej szczegółowo

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

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

Bardziej szczegółowo

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

Bazy danych. Plan wykładu. Rozproszona baza danych. Fragmetaryzacja. Cechy bazy rozproszonej. Replikacje (zalety) Wykład 15: Rozproszone bazy danych Plan wykładu Bazy danych Cechy rozproszonej bazy danych Implementacja rozproszonej bazy Wykład 15: Rozproszone bazy danych Małgorzata Krętowska, Agnieszka Oniśko Wydział Informatyki PB Bazy danych (studia

Bardziej szczegółowo

Podstawy języka SQL. SQL Structured Query Languagestrukturalny

Podstawy języka SQL. SQL Structured Query Languagestrukturalny Podstawy języka SQL SQL Structured Query Languagestrukturalny język zapytań DDL Język definicji danych (np. tworzenie tabel) DML Język manipulacji danych (np. tworzenie zapytań) DCL Język kontroli danych

Bardziej szczegółowo

Oracle PL/SQL. Paweł Rajba. pawel@ii.uni.wroc.pl http://www.kursy24.eu/

Oracle PL/SQL. Paweł Rajba. pawel@ii.uni.wroc.pl http://www.kursy24.eu/ Paweł Rajba pawel@ii.uni.wroc.pl http://www.kursy24.eu/ Zawartość modułu 6 Wprowadzenie Definiowanie wyzwalaczy DML Metadane wyzwalaczy Inne zagadnienia, tabele mutujące Wyzwalacze INSTEAD OF Wyzwalacze

Bardziej szczegółowo

Wykład 5. SQL praca z tabelami 2

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,

Bardziej szczegółowo

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

CHEATSHEET Administracja bazami danych Oracle I  Start i wyłączanie instancji CHEATSHEET Administracja bazami danych Oracle I www.jsystems.pl Start i wyłączanie instancji Shutdown immediate Shutdown normal lub shutdown Shutdown abort Shutdown transactional Startup lub startup open

Bardziej szczegółowo

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

Język zapytań SQL- język relacyjnych baz danych Język SQL Język zapytań SQL- język relacyjnych baz danych SQL (Structured Query Language),czyli Strukturalny Język Zapytań. SQL jest standardowym językiem do kierowania poleceń do relacyjnej bazy danych

Bardziej szczegółowo