Zarządzanie obiektami bazy danych Oracle11g
|
|
- Alojzy Kwiecień
- 9 lat temu
- Przeglądów:
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
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ółowoBazy 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ółowoWykł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ółowoZbió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ółowoZarzą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ółowoI. 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ółowoAutor: 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ółowoUPDATE 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ółowoBazy 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ółowostartup 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ółowoJę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ółowoLiteratura: 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ółowoInstrukcja 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ółowoJę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ółowoBlaski 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ółowoBazy 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ółowoRozdział 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ółowo1 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ółowoBazy 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ółowoTworzenie 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ółowoWyzwalacz - 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ółowoWprowadzenie 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ółowoZarzą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ółowoSQL 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ółowoLaboratorium 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ółowoUstawienie 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ółowoRozdział 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ółowoPawel@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ółowoBazy 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ółowoBazy 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ółowoUprawnienia, 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ółowoWyzwalacze. 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ółowoTworzenie 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ółowoE.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ółowoWykł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ółowoProjektowanie 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ółowoBazy 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ółowoCwiczenie 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ółowo1 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ółowoPakiety 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ółowoZbió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ółowoPlan ć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ółowoPaweł 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ółowoAspekty 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ółowo1 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ółowoServer 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ółowoprzykł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ółowoWprowadzenie 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ółowokoń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ółowoWykł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ółowoBazy 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ółowoP 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ółowoUż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ółowoOracle11g: 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ółowoIntegralność 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ółowoZarzadzanie 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ółowoPRZESTRZENNE 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ółowoPlan ć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ółowoD 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.
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ółowoPrzykł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ółowoBazy 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ółowoSQL 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ółowoJę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ółowoDECLARE 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ółowoWidok 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ółowoPlan 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ółowoInternetowe 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ółowoSELECT * 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ółowoPrzygotowanie 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ółowoSQL :: 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ółowoPawel@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ółowoBazy 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ółowoSQL> 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ółowoInstytut 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ółowoIle 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ółowoProcedury 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ółowoTransakcje. (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ółowoSprawdzenie 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ółowoBazy 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ółowo1. 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ółowoBazy 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ółowoPL/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ółowoOracle 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ółowoObiekty 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ółowoBazy 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ółowo77. 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ółowo2010-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ółowo1. 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ółowoProcedury 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ółowoZarzą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ółowoBazy 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ółowoPrzykł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ółowoBazy 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ółowoPodstawy 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ółowoOracle 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ółowoWykł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ółowoCHEATSHEET 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ółowoJę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