Zbiór zadań z SQLa z elementami T-SQLa. (Wersja robocza z dnia r.) (Zgłaszanie usterek

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

Download "Zbiór zadań z SQLa z elementami T-SQLa. (Wersja robocza z dnia 12.05.2015 r.) (Zgłaszanie usterek Robert.Fidytek@inf.ug.edu.pl)"

Transkrypt

1 Zbiór zadań z SQLa z elementami T-SQLa (Wersja robocza z dnia r.) (Zgłaszanie usterek

2 opracował dr Robert Fidytek SPIS TREŚCI Zadania poziom 1 (Prosty DQL i DML) Projekcja wyników zapytań (SELECT FROM ) Sortowanie wyników zapytań (ORDER BY) Eliminowanie duplikatów wyników zapytań (DISTINCT) Selekcja wyników zapytań (WHERE) Warunki złożone (AND, OR, NOT) Predykat IN Predykat LIKE Predykat BETWEEN Wartość NULL Kolumny wyliczeniowe (COALESCE) Ograniczanie wyników wyszukiwania (TOP) Wybrane funkcje daty i czasu (DAY, MONTH, YEAR, GETDATE, DATEDIFF) Wybrane funkcje operujące na napisach (LEFT, RIGHT, LEN, UPPER, LOWER, STUFF) Modyfikacja danych w bazie danych (UPDATE) Usuwanie danych z bazy danych (DELETE) Dodawanie danych do bazy danych (INSERT)... 6 Zadania poziom 2 (Zaawansowany DML i DQL) Złączenia wewnętrzne dwóch tabel Złączenia wewnętrzne większej liczby tabel Funkcje agregujące bez grupowania Funkcje agregujące z grupowaniem (GROUP BY, złączenia zewnętrzne) Warunki na funkcje agregujące (HAVING) Podzapytania nieskorelowane z użyciem funkcji agregujących bez grupowania Podzapytania nieskorelowane z predykatem IN Funkcje agregujące i podzapytania Modyfikacja danych w bazie danych (UPDATE i podzapytania) Usuwanie danych z bazy danych (DELETE i podzapytania) Operacje na zbiorach danych (UNION, UNION ALL, INTERSECT, EXCEPT)... 9 Zadania poziom 3 (Struktura bazy danych) Tworzenie tabel (CREATE TABLE)

3 29 Modyfikacja struktury tabeli (ALTER TABLE) Usuwanie tabel, kolumn w tabeli i ograniczeń (DROP i ALTER) Usuwanie i modyfikacja kaskadowa (CREATE i ALTER) Zadania poziom 4 (Oprogramowywanie bazy danych) Tworzenie procedur składowych (CREATE PROCEDURE) Tworzenie funkcji składowych (CREATE FUNCTION) Tworzenie widoków (złączenia zewnętrzne, CREATE VIEW) Tworzenie indeksów (CREATE INDEX) Tworzenie wyzwalaczy typu AFTER (CREATE TRIGGER) Tworzenie wyzwalaczy typu INSTEAD OF (CREATE TRIGGER) Zadania poziom 5 (Programowanie w T-SQL) Wyzwalacze i kursory Widoki + CASE Procedury + dynamiczny SQL Inne zadania, ciekawostki

4 TREŚCI ZADAŃ Zadania poziom 1 (Prosty DQL i DML) 1 Projekcja wyników zapytań (SELECT FROM ) 1.1 Wyświetlić zawartość wszystkich kolumn z tabeli pracownik. 1.2 Z tabeli pracownik wyświetlić same imiona pracowników. 1.3 Wyświetlić zawartość kolumn imię, nazwisko i dział z tabeli pracownik. 2 Sortowanie wyników zapytań (ORDER BY) 2.1 Wyświetlić zawartość kolumn imię, nazwisko i pensja z tabeli pracownik. Wynik posortuj malejąco względem pensji. 2.2 Wyświetl zawartość kolumn nazwisko i imię z tabeli pracownik. Wynik posortuj rosnąco (leksykograficznie) względem nazwiska i imienia. 2.3 Wyświetlić zawartość kolumn nazwisko, dział, stanowisko z tabeli pracownik. Wynik posortuj rosnąco względem działu, a dla tych samych nazw działów malejąco względem stanowiska. 3 Eliminowanie duplikatów wyników zapytań (DISTINCT) 3.1 Wyświetlić niepowtarzające się wartości kolumny dział z tabeli pracownik. 3.2 Wyświetlić unikatowe wiersze zawierające wartości kolumn dział i stanowisko w tabeli pracownik. 3.3 Wyświetlić unikatowe wiersze zawierające wartości kolumn dział i stanowisko w tabeli pracownik. Wynik posortuj malejąco względem działu i stanowiska. 4 Selekcja wyników zapytań (WHERE) 4.1 Znajdź pracowników o imieniu Jan. Wyświetl ich imiona i nazwiska. 4.2 Wyświetlić imiona i nazwiska pracowników pracujących na stanowisku sprzedawca. 4.3 Wyświetlić imiona, nazwiska, pensje pracowników, którzy zarabiają powyżej 1500 zł. Wynik posortuj malejąco względem pensji. 5 Warunki złożone (AND, OR, NOT) 5.1 Z tabeli pracownik wyświetlić imiona, nazwiska, działy, stanowiska tych pracowników, którzy pracują w dziale obsługi klienta na stanowisku sprzedawca. 5.2 Znaleźć pracowników pracujących w dziale technicznym na stanowisku kierownika lub sprzedawcy. Wyświetl imię, nazwisko, dział, stanowisko. 5.3 Znaleźć samochody, które nie są marek fiat i ford. 4

5 6 Predykat IN 6.1 Znaleźć samochody marek mercedes, seat i opel. 6.2 Znajdź pracowników o imionach Anna, Marzena i Alicja. Wyświetl ich imiona, nazwiska i daty zatrudnienia. 6.3 Znajdź klientów, którzy nie mieszkają w Warszawie lub we Wrocławiu. Wyświetl ich imiona, nazwiska i miasta zamieszkania. 7 Predykat LIKE 7.1 Wyświetlić imiona i nazwiska klientów, których nazwisko zawiera literę K. 7.2 Wyświetlić imiona i nazwiska klientów, dla których nazwisko zaczyna się na D, a kończy się na SKI. 7.3 Znaleźć imiona i nazwiska klientów, których nazwisko zawiera drugą literę O lub A. 8 Predykat BETWEEN 8.1 Z tabeli samochód wyświetlić wiersze, dla których pojemność silnika jest z przedziału [1100,1600]. 8.2 Znaleźć pracowników, którzy zostali zatrudnieni pomiędzy datami a Znaleźć samochody, dla których przebieg jest pomiędzy a km lub pomiędzy a km. 9 Wartość NULL 9.1 Znaleźć pracowników, którzy nie mają określonego dodatku do pensji. 9.2 Wyświetlić klientów, którzy posiadają kartę kredytową. 9.3 Dla każdego pracownika wyświetl imię, nazwisko i wysokość dodatku. Wartość NULL z kolumny dodatek powinna być wyświetlona jako 0. Wskazówka: Użyj funkcji COALESCE. 10 Kolumny wyliczeniowe (COALESCE) 10.1 Wyświetlić imiona, nazwiska pracowników ich pensje i dodatki oraz kolumnę wyliczeniową do_zapłaty, zawierającą sumę pensji i dodatku. Wskazówka: Wartość NULL z kolumny dodatek powinna być wyświetlona jako zero Dla każdego pracownika wyświetl imię, nazwisko i wyliczeniową kolumnę nowa_pensja, która będzie miała o 50% większą wartość niż dotychczasowa pensja Dla każdego pracownika oblicz ile wynosi 1% zarobków (pensja + dodatek). Wyświetl imię, nazwisko i obliczony 1%. Wyniki posortuj rosnąco względem obliczonego 1%. 11 Ograniczanie wyników wyszukiwania (TOP) 11.1 Znajdź imię i nazwisko pracownika, który jako pierwszy został zatrudniony w wypożyczalni samochodów. (Jest tylko jeden taki pracownik.) 11.2 Wyświetl pierwszych czterech pracowników z alfabetycznej listy (nazwiska i imiona) wszystkich pracowników. (W tym zadaniu nie musisz się przejmować powtórkami imion i nazwisk, ale gdybyś chciał to sprawdź konstrukcję SELECT TOP x WITH TIES ) 5

6 11.3 Wyszukaj informację o ostatnim wypożyczeniu samochodu. 12 Wybrane funkcje daty i czasu (DAY, MONTH, YEAR, GETDATE, DATEDIFF) 12.1 Wyszukaj pracowników zatrudnionych w maju. Wyświetl ich imiona, nazwiska i datę zatrudnienia. Wynik posortuj rosnąco względem nazwiska i imienia. Wskazówka: Zajrzyj do dokumentacji MS SQL i poczytaj o funkcjach: DAY, MONTH, YEAR, GETDATE, DATEDIFF Dla każdego pracownika (imię i nazwisko) oblicz ile już pracuje dni. Wynik posortuj malejąco według ilości przepracowanych dni Dla każdego samochodu (marka, typ) oblicz ile lat upłynęło od jego produkcji. Wynik posortuj malejąco po ilości lat. 13 Wybrane funkcje operujące na napisach (LEFT, RIGHT, LEN, UPPER, LOWER, STUFF) 13.1 Wyświetl imię, nazwisko i inicjały każdego klienta. Wynik posortuj względem inicjałów, nazwiska i imienia klienta. Wskazówka: Zajrzyj do dokumentacji MS SQL i poczytaj o funkcjach: LEFT, RIGHT, LEN, UPPER, LOWER, STUFF Wyświetl imiona i nazwiska klientów w taki sposób, aby pierwsza litera imienia i nazwiska była wielka, a pozostałe małe Wyświetl imiona, nazwiska i numery kart kredytowych klientów. Każda z ostatnich sześciu cyfr wyświetlanego numeru karty kredytowej klienta powinna być zastąpiona znakiem x. 14 Modyfikacja danych w bazie danych (UPDATE) 14.1 Pracownikom, którzy nie mają określonej wysokości dodatku nadaj dodatek w wysokości 50 zł Klientowi o identyfikatorze równym 10 zmień imię i nazwisko na Jerzy Nowak Zwiększ o 100 zł dodatek pracownikom, których pensja jest mniejsza niż 1500 zł. 15 Usuwanie danych z bazy danych (DELETE) 15.1 Usunąć klienta o identyfikatorze równym Usunąć wszystkie informacje o wypożyczeniach dla klienta o identyfikatorze równym Usuń wszystkie samochody o przebiegu większym niż Dodawanie danych do bazy danych (INSERT) 16.1 Dodaj do bazy danych klienta o identyfikatorze równym 121: Adam Cichy zamieszkały ul. Korzenna 12, Warszawa, tel Dodaj do bazy danych nowy samochód o identyfikatorze równym 50: srebrna skoda octavia o pojemności silnika 1896 cm 3 wyprodukowana 1 września 2012 r. i o przebiegu km. 6

7 16.3 Dodaj do bazy danych pracownika: Alojzy Mikos zatrudniony od 11 sierpnia 2010 r. w dziale zaopatrzenie na stanowisku magazyniera z pensją 3000 zł i dodatkiem 50 zł, telefon do pracownika: , pracownik pracuje w Warszawie na ul. Lewartowskiego 12. Zadania poziom 2 (Zaawansowany DML i DQL) 17 Złączenia wewnętrzne dwóch tabel 17.1 Wyszukaj samochody, który nie zostały zwrócone. (Data oddania samochodu ma mieć wartość NULL.) Wyświetl identyfikator, markę i typ samochodu oraz jego datę wypożyczenia i oddania Wyszukaj klientów, którzy nie zwrócili jeszcze samochodu. (Data oddania samochodu ma mieć wartość NULL.) Wyświetl imię i nazwisko klienta oraz identyfikator samochodu i datę wypożyczenia nie zwróconego jeszcze samochodu. Wynik posortuj rosnąco względem nazwiska i imienia klienta Wśród klientów wypożyczalni wyszukaj daty i kwoty wpłaconych przez nich kaucji. Wyświetl imię i nazwisko klienta oraz datę wpłacenia kaucji (data wypożyczenia samochodu jest równocześnie datą wpłacenia kaucji) i jej wysokość (pomiń kaucje mające wartość NULL). 18 Złączenia wewnętrzne większej liczby tabel 18.1 Dla każdego klienta, który choć raz wypożyczył samochód, wyszukaj jakie i kiedy wypożyczył samochody. Wyświetl imię i nazwisko klienta oraz datę wypożyczenia, markę i typ wypożyczonego samochodu. Wynik posortuj rosnąco po nazwisku i imieniu klienta oraz marce i typie samochodu Dla każdej filii wypożyczalni samochodów (tabela miejsce) wyszukaj jakie samochody były wypożyczane. Wyświetl adres filii (ulica i numer) oraz markę i typ wypożyczonego samochodu. Wyniki posortuj rosnąco względem adresu filii, marki i typu samochodu Dla każdego wypożyczonego samochodu wyszukaj informację jacy klienci go wypożyczali. Wyświetl identyfikator, markę i typ samochodu oraz imię i nazwisko klienta. Wyniki posortuj rosnąco po identyfikatorze samochodu oraz nazwisku i imieniu klienta. 19 Funkcje agregujące bez grupowania 19.1 Znaleźć największą pensję pracownika wypożyczalni samochodów Znaleźć średnią pensję pracownika wypożyczalni samochodów Znaleźć najwcześniejszą datę wyprodukowania samochodu. 20 Funkcje agregujące z grupowaniem (GROUP BY, złączenia zewnętrzne) 20.1 Dla każdego klienta wypisz imię, nazwisko i łączną ilość wypożyczeń samochodów (nie zapomnij o zerowej liczbie wypożyczeń). Wynik posortuj malejąco względem ilości wypożyczeń Dla każdego samochodu (identyfikator, marka, typ) oblicz ilość wypożyczeń. Wynik posortuj rosnąco względem ilości wypożyczeń. (Nie zapomnij o samochodach, które ani razu nie zostały wypożyczone.) 7

8 20.3 Dla każdego pracownika oblicz ile wypożyczył samochodów klientom. Wyświetl imię i nazwisko pracownika oraz ilość wypożyczeń. Wynik posortuj malejąco po ilości wypożyczeń. (Nie zapomnij o pracownikach, którzy nie wypożyczyli żadnego samochodu.) 21 Warunki na funkcje agregujące (HAVING) 21.1 Znajdź klientów, którzy co najmniej 2 razy wypożyczyli samochód. Wypisz dla tych klientów imię, nazwisko i ilość wypożyczeń. Wynik posortuj rosnąco względem nazwiska i imienia Znajdź samochody, które były wypożyczone co najmniej 5 razy. Wyświetl identyfikator samochodu, markę, typ i ilość wypożyczeń. Wynik posortuj rosnąco względem marki i typu samochodu Znajdź pracowników, którzy klientom wypożyczyli co najwyżej 20 razy samochód. Wyświetl imiona i nazwiska pracowników razem z ilością wypożyczeń. Wynik posortuj rosnąco względem ilości wypożyczeń, nazwiska i imienia pracownika. (Uwzględnij pracowników, którzy nie wypożyczyli żadnego samochodu.) 22 Podzapytania nieskorelowane z użyciem funkcji agregujących bez grupowania 22.1 Wyświetl imiona, nazwiska i pensje pracowników, którzy posiadają najwyższą pensją Wyświetl pracowników (imiona, nazwiska, pensje), którzy zarabiają powyżej średniej pensji Wyszukaj samochód (marka, typ, data produkcji), który został wyprodukowany najwcześniej. Może się tak zdarzyć, że kilka samochodów zostało wyprodukowanych w ten sam "najwcześniejszy" dzień. 23 Podzapytania nieskorelowane z predykatem IN 23.1 Wyświetl wszystkie samochody (marka, typ, data produkcji), które do tej pory nie zostały wypożyczone Wyświetl klientów (imię i nazwisko), którzy do tej pory nie wypożyczyli żadnego samochodu. Wynik posortuj rosnąco względem nazwiska i imienia klienta Znaleźć pracowników (imię i nazwisko), którzy do tej pory nie wypożyczyli żadnego samochodu klientowi. 24 Funkcje agregujące i podzapytania 24.1 Znajdź samochód/samochody (id_samochod, marka, typ), który był najczęściej wypożyczany. Wynik posortuj rosnąco (leksykograficznie) względem marki i typu Znajdź klienta/klientów (id_klient, imie, nazwisko), którzy najrzadziej wypożyczali samochody. Wynik posortuj rosnąco względem nazwiska i imienia. Nie uwzględniaj klientów, którzy ani razu nie wypożyczyli samochodu Znajdź pracownika/pracowników (id_pracownik, nazwisko, imie), który wypożyczył najwięcej samochodów klientom. Wynik posortuj rosnąco (leksykograficznie) względem nazwiska i imienia pracownika. 25 Modyfikacja danych w bazie danych (UPDATE i podzapytania) 25.1 Podwyższyć o 10% pensję pracownikom, którzy zarabiają poniżej średniej Pracownikom, którzy w maju wypożyczyli samochód klientowi zwiększ dodatek o 10 zł Obniżyć pensje o 5% wszystkim pracownikom którzy nie wypożyczyli klientowi samochodu w 1999 roku. 8

9 26 Usuwanie danych z bazy danych (DELETE i podzapytania) 26.1 Usunąć klientów, którzy nie wypożyczyli żadnego samochodu Usunąć samochody, które nie zostały ani razu wypożyczone Usunąć pracowników, którzy klientom nie wypożyczyli żadnego samochodu. 27 Operacje na zbiorach danych (UNION, UNION ALL, INTERSECT, EXCEPT) 27.1 Wyświetl razem wszystkie imiona i nazwiska pracowników i klientów. (Suma dwóch zbiorów.) Wynik posortuj względem nazwiska i imienia. Rozpatrz dwa przypadki a) z pominięciem duplikatów, b) z wyświetleniem duplikatów (pełna suma). Wskazówka: https://msdn.microsoft.com/pl-pl/library/ff848745(v=sql.110).aspx Wyświetl powtarzające się imiona i nazwiska klientów i pracowników. (Część wspólna dwóch zbiorów.) 27.3 Wyświetl imiona i nazwiska klientów, którzy nazywają się inaczej niż pracownicy. (Różnica dwóch zbiorów.) Wynik posortuj względem nazwiska i imienia. Zadania poziom 3 (Struktura bazy danych) 28 Tworzenie tabel (CREATE TABLE) 28.1 Utwórz tabelę pracownik2(id_pracownik, imie, nazwisko, pesel, data_zatr, pensja), gdzie * id_pracownik jest numerem pracownika nadawanym automatycznie, jest to klucz główny * imie i nazwisko to niepuste łańcuchy znaków zmiennej długości, * pesel unikatowy łańcuch jedenastu znaków stałej długości, * data_zatr domyślna wartość daty zatrudnienia to bieżąca data systemowa, * pensja nie może być niższa niż 1000zł Utwórz tabelę naprawa2(id_naprawa, data_przyjecia, opis_usterki, zaliczka), gdzie * id_naprawa jest unikatowym, nadawanym automatycznie numerem naprawy, jest to klucz główny, * data_przyjecia nie może być późniejsza niż bieżąca data systemowa, * opis usterki nie może być pusty, musi mieć długość powyżej 10 znaków, * zaliczka nie może być mniejsza niż 100zł ani większa niż 1000zł Utwórz tabelę wykonane_naprawy2(id_pracownik, id_naprawa, data_naprawy, opis_naprawy, cena), gdzie * id_pracownik identyfikator pracownika wykonującego naprawę, klucz obcy powiązany z tabelą pracownik2, * id_naprawa identyfikator zgłoszonej naprawy, klucz obcy powiązany z tabelą naprawa2, * data_naprawy domyślna wartość daty naprawy to bieżąca data systemowa, * opis_naprawy niepusty opis informujący o sposobie naprawy, * cena cena naprawy. 29 Modyfikacja struktury tabeli (ALTER TABLE) 29.1 Dana jest tabela CREATE TABLE student2(id_student INT IDENTITY(1,1) PRIMARY KEY, nazwisko VARCHAR(20), nr_indeksu INT, stypendium MONEY); Wprowadź ograniczenia na tabelę student2: * nazwisko niepusta kolumna, * nr_indeksu unikatowa kolumna, * stypendium nie może być niższe niż 1000zł, * dodatkowo dodaj niepustą kolumnę imie. 9

10 29.2 Dane są tabele: CREATE TABLE dostawca2(id_dostawca INT IDENTITY(1,1) PRIMARY KEY, nazwa VARCHAR(30)); CREATE TABLE towar2(id_towar INT IDENTITY(1,1) PRIMARY KEY, kod_kreskowy INT, id_dostawca INT); Zmodyfikuj powyższe tabele: * kolumna nazwa z tabeli dostawca2 powinna być unikatowa, * do tabeli towar2 dodaj niepustą kolumnę nazwa, * kolumna kod_kreskowy w tabeli towar2 powinna być unikatowa, * kolumna id_dostawca z tabeli towar2 jest kluczem obcym z tabeli dostawca Dane są tabele: CREATE TABLE kraj2(id_kraj INT IDENTITY(1,1) PRIMARY KEY, nazwa VARCHAR(30)); CREATE TABLE gatunek2(id_gatunek INT IDENTITY(1,1) PRIMARY KEY, nazwa VARCHAR(30)); CREATE TABLE zwierze2(id_zwierze INT IDENTITY(1,1) PRIMARY KEY, id_gatunek INT, id_kraj INT, cena MONEY); Zmodyfikuj powyższe tabele: * kolumny nazwa z tabel kraj2 i gatunek2 mają być niepuste, * kolumna id_gatunek z tabeli zwierze2 jest kluczem obcym z tabeli gatunek2, * kolumna id_kraj z tabeli zwierze2 jest kluczem obcym z tabeli kraj2. 30 Usuwanie tabel, kolumn w tabeli i ograniczeń (DROP i ALTER) 30.1 Dane są tabele: CREATE TABLE kategoria2(id_kategoria INT PRIMARY KEY, nazwa VARCHAR(30) ); CREATE TABLE przedmiot2(id_przedmiot INT PRIMARY KEY, id_kategoria INT REFERENCES kategoria2(id_kategoria), nazwa VARCHAR(30)); Napisać instrukcje SQL, która usuną tabele kategoria2 i przedmiot2. Wsk: Zwróć uwagę na kolejność usuwania tabel. Wersja trudniejsza: Czy potrafisz najpierw sprawdzić, czy tabele istnieją i jeśli istnieją to dopiero wtedy je usunąć? 30.2 Dana jest tabela: CREATE TABLE osoba2(id_osoba INT, imie VARCHAR(15), imie2 VARCHAR(15) ); Napisać instrukcję SQL, która z tabeli osoba2 usunie kolumnę imie Dana jest tabela: CREATE TABLE uczen2(id_uczen INT PRIMARY KEY, imie VARCHAR(15), nazwisko VARCHAR(20) CONSTRAINT uczen_nazwisko_unique UNIQUE); Napisać instrukcję SQL, która usunie narzucony warunek unikatowości na kolumnę nazwisko. Wersja trudniejsza: Czy potrafiłbyś zrobić powyższe zadanie dla definicji tabeli: CREATE TABLE uczen2(id_uczen INT PRIMARY KEY, imie VARCHAR(15), nazwisko VARCHAR(20) CONSTRAINT UNIQUE);? 31 Usuwanie i modyfikacja kaskadowa (CREATE i ALTER) 31.1 Utwórz tabelę wlasciciel2(id_wlasciciel, imie,nazwisko,data_ur,ulica,numer,kod,miejscowosc) i zwierze2(id_zwierze,id_wlasciciel,rasa,data_ur,imie) w taki sposób, aby po usunięciu informacji o właścicielu zwierzęcia z tabeli wlasciciel2, SZBD automatycznie identyfikator właściciela w tabeli zwierze2 ustawiał na wartość NULL. Nie zapomnij o doborze pozostałych ograniczeń na kolumny (można to zrobić wg uznania) Dane są tabele: CREATE TABLE film2(id_film INT PRIMARY KEY,tytul VARCHAR(50) NOT NULL); CREATE TABLE gatunek2(id_gatunek INT PRIMARY KEY,nazwa VARCHAR(50) NOT NULL); CREATE TABLE film2_gatunek2(id_film INT,id_gatunek INT,PRIMARY KEY(id_film,id_gatunek)); Zmodyfikuj strukturę powyższych tabel (polecenie ALTER) taka aby: a) w przypadku usunięcia filmu z tabeli film2 zostały automatycznie usuwane informacje jakich gatunków był usunięty film (nie usuwamy gatunków z tabeli gatunek2), b) w przypadku usunięcia gatunku z tabeli gatunek2 zostały automatycznie usuwane informacje jakie filmy były tego gatunku (nie usuwamy filmów z tabeli film2) Dane są tabele: CREATE TABLE stanowisko2 (id_stanowisko INT PRIMARY KEY, nazwa VARCHAR(30)); CREATE TABLE pracownik2(id_pracownik INT PRIMARY KEY, id_stanowisko INT, nazwisko VARCHAR(20)); Zmodyfikuj struktury powyższych tabel tak, aby po usunięciu stanowiska z tabeli stanowisko2 identyfikator 10

11 stanowiska w tabeli pracownik2 był automatycznie ustawiany na wartość NULL oraz podczas modyfikowania identyfikatora stanowiska w tabeli stanowisko2 wszystkie identyfikatory stanowiska w tabeli pracownik2 powinny zostać automatycznie zaktualizowane. Zadania poziom 4 (Oprogramowywanie bazy danych) 32 Tworzenie procedur składowych (CREATE PROCEDURE) 32.1 Napisać procedurę o nazwie wypisz_samochody, która posiada tylko jeden parametr - marka samochodu. Procedura powinna wyświetlać wszystkie informacje z tabeli samochód o samochodach zadanej marki Napisać procedurę o nazwie zwieksz_pensje posiadającą dwa parametry: identyfikator pracownika i kwotę. Procedura powinna zwiększyć pensję pracownikowi, na którego wskazuje zadany identyfikator o zadaną kwotę. Przetestuj utworzoną procedurę zwiększ pracownikowi o identyfikatorze równym 1 pensję o 1000 zł Napisz procedurę o nazwie dodaj_klienta umożliwiającą dodanie nowego klienta. Dane klienta powinny być odczytane z parametrów procedury. Dobierz odpowiednio parametry dla tworzonej procedury na podstawie kolumn tabeli klient. Przetestuj utworzoną procedurę dodaj nowego klienta. 33 Tworzenie funkcji składowych (CREATE FUNCTION) 33.1 Napisać funkcję o nazwie aktywnosc_klienta, która będzie zwracać ilość wypożyczeń samochodów dla klienta o identyfikatorze zadanym jako parametr funkcji. Przetestuj utworzoną funkcję sprawdź ile samochodów wypożyczył klient o identyfikatorze równym Napisać funkcję o nazwie ile_wypozyczen posiadającą dwa parametry data_od i data_do. Funkcja powinna zwrócić ilość wypożyczeń samochodów w zadanym przedziale czasowym. Przetestuj utworzoną funkcję sprawdź ile zostało wypożyczonych samochodów od r. do r Napisać funkcję o nazwie roznica_pensji nie posiadającą parametrów i zwracającą różnicę pomiędzy największą i najmniejszą pensją wśród pracowników wypożyczalni. Przetestuj utworzoną funkcję. 34 Tworzenie widoków (złączenia zewnętrzne, CREATE VIEW) 34.1 Utwórz widok o nazwie klient_raport zawierający informacje o ilości wypożyczeń każdego z klientów (id_klient, imie, nazwisko). Uwzględnij klientów, którzy ani razu nie wypożyczyli samochodu. Za pomocą utworzonego widoku znajdź klientów, którzy wypożyczyli samochód więcej niż raz Utwórz widok o nazwie samochod_raport zawierający informacje o ilości wypożyczeń każdego z samochodów (id_samochod, marka, typ). Uwzględnij samochody, które ani razu nie zostały wypożyczone. Za pomocą utworzonego widoku znajdź samochód/samochody, które były najczęściej wypożyczane Utwórz widok o nazwie pracownik_raport zawierający informacje o ilości wypożyczeń samochodów przez pracowników. Nie zapomnij uwzględnić pracowników, którzy nie wypożyczyli żadnego samochodu. Za pomocą utworzonego widoku znajdź pracowników, dla których ilość wypożyczeń jest większa od średniej ilości wypożyczeń samochodów przez pracowników. 35 Tworzenie indeksów (CREATE INDEX) 35.1 Utwórz unikalny indeks dla kolumny telefon w tabeli klient. 11

12 35.2 Utwórz indeks klastrowy dla kolumn nazwisko i imie w tabeli klient Utwórz indeks nieklastrowy dla kolumn marka i typ w tabeli samochód. 36 Tworzenie wyzwalaczy typu AFTER (CREATE TRIGGER) Napisać wyzwalacz, który uniemożliwi usunięcie klienta. Przetestuj utworzony wyzwalacz spróbuj usunąć wszystkich klientów Napisać wyzwalacz, który uniemożliwi dodanie pracownika z pensją i dodatkiem równym zero lub NULL. Przetestuj utworzony wyzwalacz spróbuj dodać kilku pracowników jednocześnie Napisać wyzwalacz o nazwie "duplikat_miejsce", który uniemożliwi jednorazowo dodanie więcej niż jednego miejsca oraz dodatkowo uniemożliwi dodanie miejsca o takich samych ulicach, numerze, mieście i kodzie. 37 Tworzenie wyzwalaczy typu INSTEAD OF (CREATE TRIGGER) a) Do tabeli samochód dodaj kolumnę "usuniety" typu BIT o wartości domyślnej równej 0. b) W tabeli samochod zmień wszystkie wartości kolumny usuniety z NULL na wartość 0. c) Utwórz wyzwalacz o nazwie " usuniety_samochod ", który uniemożliwi fizyczne usunięcie samochodu z tabeli samochod, a usuwany samochod oznaczy poprzez ustawienie kolumny usuniety na wartość Utwórz wyzwalacz o nazwie "usun_miejsce_i_wypozyczenia", który uniemożliwi usunięcie równocześnie więcej niż 1 miejsca z tabeli miejsce oraz przed usunięciem pojedynczego miejsca usunie najpierw wszystkie rekordy w tabeli wypożyczenie zawierające informację o usuwanym miejscu (id_miejsca_wyp, id_miejsca_odd). Przetestuj napisany wyzwalacz Utwórz wyzwalacz o nazwie "samochod_blokada", który uniemożliwia wprowadzenie jakiejkolwiek zmiany w tabeli samochód. Przetestuj utworzony wyzwalacz dla instrukcji INSERT, UPDATE, DELETE. Zadania poziom 5 (Programowanie w T-SQL) 38 Wyzwalacze i kursory 38.1 Napisać wyzwalacz, który będzie wypisywał na ekranie nazwiska i imiona usuniętych pracowników. Użyj kursora. Przetestuj utworzony wyzwalacz usuń wszystkich pracowników Stwórz tabelę o nazwie samochod_delete o identycznej strukturze jak tabela samochód. Napisz wyzwalacz, który wszystkie usunięte samochody z tabeli samochód wpisze do tabeli samochod_delete. Przetestuj utworzony wyzwalacz usuń z tabeli samochód samochody o identyfikatorach z przedziału od 1 do Napisać wyzwalacz, który po podwyżce pensji pracownikowi będzie zerował jego dodatek. Przetestuj utworzony wyzwalacz pracownikom o identyfikatorach równych 1, 2 i 3 zwiększ pensję o 200 zł. 39 Widoki + CASE 39.1 Utwórz widok o nazwie ocena_klienta, który dla każdego klienta (id_klient, imie, nazwisko) wyświetli informację, czy to jest stały klient (czyli wypisze słowo TAK lub NIE jako wartość kolumny "staly_klient"). Przyjmijmy, że stały klient to taki, który wypożyczył co najmniej dwa razy samochód. Użyj powyższego widoku i wypisz stałych klientów sortując wynik alfabetycznie po nazwisku i imieniu klienta. 12

13 39.2 Utwórz widok o nazwie pensja_pracownika, który dla każdego pracownika (id_pracownik, imie, nazwisko) wyświetli informację w nowej kolumnie o nazwie "zarobki" o rzędzie jego zarobków: MAŁO, ŚREDNIO, DUŻO. Przyjmijmy, że pracownik zarabia MAŁO jeśli pensja jest poniżej 1500 zł, zarabia ŚREDNIO jeśli pensja jest od 1500 zł do 3000 zł, a zarabia dużo jeśli pensja jest większa od 3000 zł. Użyj powyższego widoku do znalezienia pracowników zarabiających MAŁO Utwórz widok o nazwie "pracownik_informacje", który wyświetla o każdym pracowniku takie informacje jak: a) id_pracownik, b) imie, c) nazwisko, d) kolumna wyliczeniowa "staz_pracy", czyli długość zatrudnienia w latach, e) kolumna wyliczeniowa "wypozyczenia", czyli całkowita ilość wypożyczeń samochodów, f) kolumna wyliczeniowa "dodatek" z wartościami TAK/NIE/BRAK (TAK gdy dodatek>0, NIE gdy dodatek=0, BRAK w pozostałych przypadkach). Przetestuj utworzony widok wyszukując pracowników, dla których dodatek nie został przyznany. 40 Procedury + dynamiczny SQL 40.1 Napisać procedurę o nazwie "usun_widoki", która z bieżącej bazy danych usunie wszystkie widoki. Przetestuj działanie utworzonej procedury. Wsk 1: SELECT * FROM INFORMATION_SCHEMA.TABLES; Wsk 2: EXEC 40.2 Napisać procedurę o nazwie "usun_klucze_obce", która z bieżącej bazy danych usunie wszystkie klucze obce. Przetestuj działanie utworzonej procedury. Wsk 1: SELECT * FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS; 40.3 Napisać procedurę o nazwie "klient_dodaj_kolumne_rabat", która sprawdza czy w tabeli klient istnieje kolumna o nazwie "rabat", jeśli nie to dodaje ją do tabeli klient. Kolumna "rabat" powinna być typu INT i przyjmować domyślnie wartość 0. Wszyscy istniejący klienci w tabeli klient powinni mieć ustawioną wartość rabatu na 0. Przetestuj działanie procedury Napisać procedurę o nazwie "baza_reset" posiadającą jeden parametr, który jest nazwą bazy danych. Procedura ma usunąć zadaną bazę danych (o ile taka istnieje) i utworzyć ją na nowo. Przetestuj działanie procedury Napisać procedurę o nazwie "tabele_statystyka", która dla bieżącej bazy danych wyświetli w formie tabelarycznej informację o wszystkich tabelach znajdujących się w bieżącej bazie danych oraz ilości rekordów w każdej z tych tabel. Przyjmij, że kolumny uzyskanego zestawienia będą mieć nazwy: nazwa_tabeli, ilosc_rekordow. Przetestuj działanie utworzonej procedury. 41 Inne zadania, ciekawostki 41.1 Zmień domyślny format daty na dzień/miesiąc/rok Jakim skrótem klawiszowym zakomentować/odkomentować fragment kodu T-SQL pisanym w SQL Server Management Studio. 13

14 ROZWIĄZANIA ZADAŃ 1.1 SELECT * FROM pracownik; 2.1 SELECT imie, nazwisko, pensja FROM pracownik ORDER BY pensja DESC; 3.1 SELECT DISTINCT dzial FROM pracownik; 4.1 SELECT imie, nazwisko FROM pracownik WHERE imie='jan'; 5.1 SELECT imie, nazwisko, dzial, stanowisko FROM pracownik WHERE dzial='obsługa klienta' AND stanowisko='sprzedawca'; 6.1 SELECT * FROM samochod WHERE marka IN ('Mercedes','Seat','Opel'); 7.1 SELECT imie, nazwisko FROM klient WHERE nazwisko LIKE '%k%'; 8.1 SELECT * FROM samochod WHERE poj_silnika BETWEEN 1100 AND 1600; 9.1 SELECT * FROM pracownik WHERE dodatek IS NULL; 10.1 SELECT imie, nazwisko, pensja, dodatek, pensja+coalesce(dodatek,0) AS do_zaplaty FROM pracownik; 11.1 SELECT TOP 1 imie, nazwisko FROM pracownik ORDER BY data_zatr ASC; 12.1 SELECT imie, nazwisko, data_zatr FROM pracownik WHERE MONTH(data_zatr)=5 ORDER BY nazwisko ASC, imie ASC; 13.1 SELECT imie, nazwisko, LEFT(imie,1)+'. '+LEFT(nazwisko,1)+'.' AS inicjaly FROM klient ORDER BY inicjaly, nazwisko, imie; 14.1 UPDATE pracownik SET dodatek=50 WHERE dodatek IS NULL; 15.1 DELETE FROM klient WHERE id_klient=17; 16.1 INSERT INTO klient (id_klient,imie,nazwisko,ulica,numer,kod,miasto,telefon) VALUES(121,'Adam','Cichy','Korzenna','12','00-950','Warszawa',' '); 17.1 SELECT s.id_samochod, s.marka, s.typ, w.data_wyp, w.data_odd FROM samochod s INNER JOIN wypozyczenie w ON s.id_samochod=w.id_samochod WHERE w.data_odd IS NULL; 18.1 SELECT k.imie, k.nazwisko, w.data_wyp, s.marka, s.typ FROM klient k INNER JOIN wypozyczenie w ON k.id_klient=w.id_klient INNER JOIN samochod s ON w.id_samochod=s.id_samochod ORDER BY k.nazwisko, k.imie, s.marka, s.typ; 19.1 SELECT MAX(pensja) FROM pracownik; 14

15 20.1 SELECT k.imie, k.nazwisko, COUNT(w.id_klient) AS ilosc_wypozyczen FROM klient k LEFT JOIN wypozyczenie w ON k.id_klient=w.id_klient GROUP BY k.imie, k.nazwisko, k.id_klient ORDER BY COUNT(w.id_klient) DESC; 21.1 SELECT k.imie, k.nazwisko, COUNT(w.id_klient) AS ilosc_wypozyczen FROM klient k INNER JOIN wypozyczenie w ON k.id_klient=w.id_klient GROUP BY k.imie, k.nazwisko, k.id_klient HAVING COUNT(w.id_klient)>=2 ORDER BY nazwisko ASC, imie ASC; 22.1 SELECT imie, nazwisko, pensja FROM pracownik WHERE pensja=(select MAX(pensja) FROM pracownik); 23.1 SELECT marka, typ, data_prod FROM samochod WHERE id_samochod NOT IN (SELECT DISTINCT id_samochod FROM wypozyczenie); 24.1 SELECT s.id_samochod, s.marka, s.typ FROM samochod s JOIN wypozyczenie w ON s.id_samochod=w.id_samochod GROUP BY s.id_samochod, s.marka, s.typ HAVING COUNT(w.id_samochod) = ( SELECT TOP 1 COUNT(w.id_samochod) AS ilosc FROM wypozyczenie w GROUP BY w.id_samochod ORDER BY ilosc DESC ) ORDER BY s.marka ASC, s.typ ASC; Rozwiązanie z użyciem z T-SQL konstrukcji TOP 1 WITH TIES: SELECT TOP 1 WITH TIES s.id_samochod, s.marka, s.typ, COUNT(w.id_samochod) AS ilosc_wyp FROM samochod s JOIN wypozyczenie w ON s.id_samochod=w.id_samochod GROUP BY s.id_samochod, s.marka, s.typ ORDER BY ilosc_wyp DESC, s.marka ASC, s.typ ASC; 25.1 UPDATE pracownik SET pensja=1.1*pensja WHERE pensja < (SELECT AVG(pensja) FROM pracownik); 26.1 DELETE FROM klient WHERE id_klient NOT IN (SELECT DISTINCT id_klient FROM wypozyczenie); 27.1 a) SELECT imie, nazwisko FROM klient UNION SELECT imie, nazwisko FROM pracownik ORDER BY 2, 1; b) SELECT imie, nazwisko FROM klient UNION ALL SELECT imie, nazwisko FROM pracownik ORDER BY 2, 1; 15

16 DROP TABLE pracownik2; -- CREATE TABLE pracownik2( id_pracownik INT IDENTITY(1,1) PRIMARY KEY, imie VARCHAR(15) NOT NULL, nazwisko VARCHAR(20) NOT NULL, pesel CHAR(11) UNIQUE, data_zatr DATETIME DEFAULT GETDATE(), pensja MONEY CHECK(pensja>=1000) ); 29.1 ALTER TABLE student2 ALTER COLUMN nazwisko VARCHAR(20) NOT NULL; ALTER TABLE student2 ADD CONSTRAINT unikatowy_nr_indeksu UNIQUE (nr_indeksu); ALTER TABLE student2 ADD CONSTRAINT sprawdz_stypendium CHECK (stypendium>=1000); ALTER TABLE student2 ADD imie VARCHAR(15) NOT NULL; wersja podstawowa DROP TABLE przedmiot2; DROP table kategoria2; --wersja trudeniejsza IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE table_name='przedmiot2') DROP TABLE przedmiot2; IF EXISTS (SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE table_name='kategoria2') DROP TABLE kategoria2; DROP TABLE zwierze2; --DROP TABLE wlasciciel2; CREATE TABLE wlasciciel2( id_wlasciciel INT IDENTITY(1,1)PRIMARY KEY, imie VARCHAR(15) NOT NULL CHECK(LEN(imie)>2), nazwisko VARCHAR(15) NOT NULL CHECK(LEN(nazwisko)>2), data_ur DATE NOT NULL DEFAULT GETDATE(), ulica VARCHAR(50), numer VARCHAR(8), kod CHAR(6) NOT NULL CHECK(LEN(kod)=6), miejscowosc VARCHAR(30) NOT NULL CHECK(LEN(miejscowosc)>1) ); CREATE TABLE zwierze2( id_zwierze INT IDENTITY(1,1) PRIMARY KEY, id_wlasciciel INT REFERENCES wlasciciel2(id_wlasciciel) ON DELETE SET NULL, rasa VARCHAR(30) NOT NULL CHECK(LEN(rasa)>2), data_ur DATE NOT NULL DEFAULT GETDATE(), imie VARCHAR(15) NOT NULL CHECK(LEN(imie)>2) ); --INSERT INTO wlasciciel2(imie,nazwisko,data_ur,ulica,numer,kod,miejscowosc) --VALUES ('Jan','Kos',' ','Polna','1','11-222','Nysa'); 16

17 --INSERT INTO zwierze2(id_wlasciciel,rasa,data_ur,imie) --VALUES (1,'Jamnik',' ','Krótki'); --SELECT * FROM zwierze2; --DELETE FROM wlasciciel2 WHERE id_wlasciciel=1; --SELECT * FROM zwierze2; DROP PROCEDURE wypisz_samochody; CREATE PROCEDURE VARCHAR(20) AS SELECT * FROM samochod WHERE EXECUTE wypisz_samochody 'opel'; DROP FUNCTION dbo.aktywnosc_klienta; -- CREATE FUNCTION dbo.aktywnosc_klienta INT ) RETURNS INT BEGIN RETURN (SELECT COUNT(*) FROM wypozyczenie WHERE END; SELECT dbo.aktywnosc_klienta(3) AS ile_wyp; DROP VIEW klient_raport; -- CREATE VIEW klient_raport AS SELECT k.id_klient, k.imie, k.nazwisko, COUNT(w.id_klient) AS "ilosc_wyp" FROM klient k LEFT JOIN wypozyczenie w ON k.id_klient=w.id_klient GROUP BY k.id_klient, k.imie, k.nazwisko; SELECT * FROM klient_raport WHERE ilosc_wyp>1; DROP INDEX klient.index_klient_telefon; -- CREATE UNIQUE INDEX index_klient_telefon ON klient(telefon); DROP TRIGGER klient_anuluj_usuwanie; -- CREATE TRIGGER klient_anuluj_usuwanie ON klient FOR DELETE AS RAISERROR('Zabronione jest usuwanie klientów!',1,2) 17

18 ROLLBACK DELETE FROM klient; 37.1 ALTER TABLE samochod ADD usuniety BIT DEFAULT 0; UPDATE samochod SET usuniety=0; CREATE TRIGGER usuniety_samochod ON samochod INSTEAD OF DELETE AS BEGIN UPDATE samochod SET usuniety=1 WHERE id_samochod IN (SELECT id_samochod FROM deleted) END DELETE FROM samochod WHERE id_samochod=3; SELECT * FROM samochod; DROP TRIGGER pracownik_usuwanie; -- CREATE TRIGGER pracownik_usuwanie ON pracownik FOR DELETE AS BEGIN --deklaracja kursora DECLARE kursor_deleted CURSOR FOR SELECT imie, nazwisko FROM deleted; --otwarcie kursora OPEN kursor_deleted --zmienne pomocnicze do przechowywania danych pobranych z kursora varchar(20) --pobranie pierwszego wiersza z kursora FETCH NEXT FROM --wykonuj dopóki pobranie wiersza z kursora zakończy się sukcesem WHILE = 0 BEGIN --wyswietlenie wartosci print 'Usunięto: --pobranie kolejnego wiersza z kursora FETCH NEXT FROM END --zamkniecie kursora CLOSE kursor_deleted --usuniecie kursora z bazy danych DEALLOCATE kursor_deleted 18

19 END DELETE FROM pracownik 39.1 CREATE VIEW ocena_klienta AS SELECT k.id_klient, k.imie, k.nazwisko, CASE WHEN COUNT(w.id_klient)>=2 THEN 'TAK' ELSE 'NIE' END AS staly_klient FROM klient k LEFT JOIN wypozyczenie w ON k.id_klient=w.id_klient GROUP BY k.id_klient, k.imie, k.nazwisko; SELECT * FROM ocena_klienta WHERE staly_klient='tak' ORDER BY nazwisko, imie; 40.1 CREATE PROCEDURE usun_widoki AS BEGIN NVARCHAR(200); WHILE EXISTS(SELECT TOP 1 1 FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_CATALOG=DB_NAME() AND TABLE_TYPE='VIEW') BEGIN VIEW ' + TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_CATALOG=DB_NAME() AND TABLE_TYPE='VIEW'; EXEC END END EXEC usun_widoki; 41.1 SET DATEFORMAT dmy; 19

Zadania z SQLa (MS SQL Server)

Zadania z SQLa (MS SQL Server) Zadania z SQLa (MS SQL Server) Struktura testowej bazy danych (diagram ERD): opracował dr Robert Fidytek SPIS TYPÓW ZADAŃ 1 Projekcja wyników zapytań (SELECT FROM )... 3 2 Sortowanie wyników zapytań (ORDER

Bardziej szczegółowo

opisuje nazwy kolumn, wyrażenia arytmetyczne, funkcje nazwy tabel lub widoków warunek (wybieranie wierszy)

opisuje nazwy kolumn, wyrażenia arytmetyczne, funkcje nazwy tabel lub widoków warunek (wybieranie wierszy) Zapytania SQL. Polecenie SELECT jest używane do pobierania danych z bazy danych (z tabel lub widoków). Struktura polecenia SELECT SELECT FROM WHERE opisuje nazwy kolumn, wyrażenia arytmetyczne, funkcje

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

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

Bazy danych SQL Server 2005

Bazy danych SQL Server 2005 Bazy danych SQL Server 2005 TSQL Michał Kuciapski Typ zadania: Podstawowe zapytania Select Zadanie 1: Wyświetl następujące informacje z bazy: A. 1. Wyświetl informacje o klientach: nazwa firmy, imie, nazwisko,

Bardziej szczegółowo

Podstawowe zapytania SELECT (na jednej tabeli)

Podstawowe zapytania SELECT (na jednej tabeli) Podstawowe zapytania SELECT (na jednej tabeli) Struktura polecenia SELECT SELECT opisuje nazwy kolumn, wyrażenia arytmetyczne, funkcje FROM nazwy tabel lub widoków WHERE warunek (wybieranie wierszy) GROUP

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

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

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

Bardziej szczegółowo

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

Plan bazy: Kod zakładający bazę danych: DROP TABLE noclegi CASCADE; CREATE TABLE noclegi( id_noclegu SERIAL NOT NULL, Mój projekt przedstawia bazę danych noclegów składającą się z 10 tabel. W projekcie wykorzystuje program LibreOffice Base do połączenia psql z graficznym interfejsem ( kilka formularzy przedstawiających

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

Relacyjne bazy danych. Podstawy SQL

Relacyjne bazy danych. Podstawy SQL Relacyjne bazy danych Podstawy SQL Język SQL SQL (Structured Query Language) język umożliwiający dostęp i przetwarzanie danych w bazie danych na poziomie obiektów modelu relacyjnego tj. tabel i perspektyw.

Bardziej szczegółowo

Wstęp wprowadzający do laboratorium 2. mgr inż. Rafał Grycuk

Wstęp wprowadzający do laboratorium 2. mgr inż. Rafał Grycuk Wstęp wprowadzający do laboratorium 2 mgr inż. Rafał Grycuk Plan prezentacji 1. Czym jest T-SQL i czym się różni od standardu SQL 2. Typy zapytań 3. Zapytanie typu SELECT 4. Słowo o indeksach T-SQL (1)

Bardziej szczegółowo

BAZA DANYCH SIECI HOTELI

BAZA DANYCH SIECI HOTELI Paulina Gogół s241906 BAZA DANYCH SIECI HOTELI Baza jest częścią systemu zarządzającego pewną siecią hoteli. Składa się z tabeli powiązanych ze sobą różnymi relacjami. Służy ona lepszemu zorganizowaniu

Bardziej szczegółowo

SQL (ang. Structured Query Language)

SQL (ang. Structured Query Language) SQL (ang. Structured Query Language) SELECT pobranie danych z bazy, INSERT umieszczenie danych w bazie, UPDATE zmiana danych, DELETE usunięcie danych z bazy. Rozkaz INSERT Rozkaz insert dodaje nowe wiersze

Bardziej szczegółowo

Bazy Danych - Instrukcja do Ćwiczenia laboratoryjnego nr 8

Bazy Danych - Instrukcja do Ćwiczenia laboratoryjnego nr 8 Bazy Danych - Instrukcja do Ćwiczenia laboratoryjnego nr 8 Bazowy skrypt PHP do ćwiczeń z bazą MySQL: Utwórz skrypt o nazwie cw7.php zawierający następującą treść (uzupełniając go o właściwą nazwę uŝytkownika

Bardziej szczegółowo

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

Wykład 5 funkcje i procedury pamiętane widoki (perspektywy) wyzwalacze Wykład 5 funkcje i procedury pamiętane widoki (perspektywy) wyzwalacze 1 Funkcje i procedury pamiętane Następujące polecenie tworzy zestawienie zawierające informację o tym ilu jest na naszej hipotetycznej

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

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

Systemowe aspekty baz

Systemowe aspekty baz Systemowe aspekty baz danych Deklaracja zmiennej Zmienne mogą być wejściowe i wyjściowe Zmienne w T-SQL można deklarować za pomocą @: declare @nazwisko varchar(20) Zapytanie z użyciem zmiennej: select

Bardziej szczegółowo

Hurtownia Świętego Mikołaja projekt bazy danych

Hurtownia Świętego Mikołaja projekt bazy danych Aleksandra Kobusińska nr indeksu: 218366 Hurtownia Świętego Mikołaja projekt bazy danych Zaprezentowana poniżej baza jest częścią większego projektu bazy danych wykorzystywanej w krajowych oddziałach wiosek

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

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

BAZY DANYCH PROJEKT. Tomasz Osmelak, 258441 Wrocław, 26.01.2014 Instytut Matematyczny Wydział Matematyki I Informatyki Uniwersytet Wrocławski

BAZY DANYCH PROJEKT. Tomasz Osmelak, 258441 Wrocław, 26.01.2014 Instytut Matematyczny Wydział Matematyki I Informatyki Uniwersytet Wrocławski Tomasz Osmelak, 258441 Wrocław, 26.01.2014 Instytut Matematyczny Wydział Matematyki I Informatyki Uniwersytet Wrocławski BAZY DANYCH PROJEKT Sprawdzający: dr hab. Robert Stańczy 1 Spis treści: 1. Schemat

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

Przestrzenne bazy danych Podstawy języka SQL

Przestrzenne bazy danych Podstawy języka SQL Przestrzenne bazy danych Podstawy języka SQL Stanisława Porzycka-Strzelczyk porzycka@agh.edu.pl home.agh.edu.pl/~porzycka Konsultacje: wtorek godzina 16-17, p. 350 A (budynek A0) 1 SQL Język SQL (ang.structured

Bardziej szczegółowo

Microsoft SQL Server Podstawy T-SQL

Microsoft SQL Server Podstawy T-SQL Itzik Ben-Gan Microsoft SQL Server Podstawy T-SQL 2012 przełożył Leszek Biolik APN Promise, Warszawa 2012 Spis treści Przedmowa.... xiii Wprowadzenie... xv Podziękowania... xix 1 Podstawy zapytań i programowania

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

Wstęp 5 Rozdział 1. Podstawy relacyjnych baz danych 9

Wstęp 5 Rozdział 1. Podstawy relacyjnych baz danych 9 Wstęp 5 Rozdział 1. Podstawy relacyjnych baz danych 9 Tabele 9 Klucze 10 Relacje 11 Podstawowe zasady projektowania tabel 16 Rozdział 2. Praca z tabelami 25 Typy danych 25 Tworzenie tabel 29 Atrybuty kolumn

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

Język SQL podstawy zapytań

Język SQL podstawy zapytań Język SQL podstawy zapytań 1 Plan prezentacji 1. Krótka historia języka SQL 2. Cechy języka SQL 3. Przykładowa baza danych 4. Podstawy zapytań - operacje na modelu relacyjnym 5. Polecenie SELECT zapytania

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

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

W SQL Serwerze 2008 wprowadzono parametry tablicowe (Table Valued Parameters - TVP). Procedury składowane c.d. Parametry tablicowe w Transact-SQL. W SQL Serwerze 2008 wprowadzono parametry tablicowe (Table Valued Parameters - TVP). Zadanie 1. Proszę napisad procedurę składowaną, która

Bardziej szczegółowo

Monika Sychla 241858 Daniel Smolarek 241875. Projekt bazy danych

Monika Sychla 241858 Daniel Smolarek 241875. Projekt bazy danych Monika Sychla 241858 Daniel Smolarek 241875 Projekt bazy danych Naszym zadaniem było zaprojektowanie przykładowej bazy danych, w oparciu o zagadnienia jakie zostały wprowadzone w trakcie kursu z baz danych.

Bardziej szczegółowo

Kurs. Podstawy MySQL

Kurs. Podstawy MySQL Kurs Podstawy MySQL Krótkie info. Autorem kursu jest Piotr Jędrusik. Kurs jest własnością serwisu MySQL FAQ www.mysqlfaq.prv.pl, email: mysqlfaq@twister.pl. 1. Tworzymy bazę. Stworzymy pierwszą bazę o

Bardziej szczegółowo

1: 2: 3: 4: 5: 6: 7: 8: 9: 10:

1: 2: 3: 4: 5: 6: 7: 8: 9: 10: Grupa A (LATARNIE) Imię i nazwisko: Numer albumu: 1: 2: 3: 4: 5: 6: 7: 8: 9: 10: Nazwisko prowadzącego: 11: 12: Suma: Ocena: Zad. 1 (10 pkt) Dana jest relacja T. Podaj wynik poniższego zapytania (podaj

Bardziej szczegółowo

BAZY DANYCH Cz III. Transakcje, Triggery

BAZY DANYCH Cz III. Transakcje, Triggery BAZY DANYCH Cz III Transakcje, Triggery Transakcje Definicja: Zbiór operacji (modyfikacja danych, usuwanie, wstawianie, tworzenie obiektów bazodanowych), które albo wszystkie kończone są sukcesem, albo

Bardziej szczegółowo

Systemowe aspekty baz danych

Systemowe aspekty baz danych Systemowe aspekty baz danych Deklaracja zmiennej Zmienne mogą być wejściowe i wyjściowe Zmienne w T-SQL można deklarować za pomocą @: declare @nazwisko varchar(20) Zapytanie z użyciem zmiennej: select

Bardziej szczegółowo

SQL 4 Structured Query Lenguage

SQL 4 Structured Query Lenguage Wykład 5 SQL 4 Structured Query Lenguage Instrukcje sterowania danymi Bazy Danych - A. Dawid 2011 1 CREATE USER Tworzy nowego użytkownika Składnia CREATE USER specyfikacja użytkownika [, specyfikacja użytkownika]...

Bardziej szczegółowo

Administracja i programowanie pod Microsoft SQL Server 2000

Administracja i programowanie pod Microsoft SQL Server 2000 Administracja i programowanie pod Paweł Rajba pawel@ii.uni.wroc.pl http://www.kursy24.eu/ Zawartość modułu 6 Wyzwalacze Wprowadzenie Tworzenie wyzwalacza Wyzwalacze typu,,po'' Wyzwalacze typu,,zamiast''

Bardziej szczegółowo

a) Polecenie: Wyświetl wszystkie rekordy z tabeli Pracownicy (wszystkie atrybuty)

a) Polecenie: Wyświetl wszystkie rekordy z tabeli Pracownicy (wszystkie atrybuty) Ćwiczenia MS Access/SQL I. Zadania podstawowe 1. Wyświetlanie zawartości tabeli a) Polecenie: Wyświetl wszystkie rekordy z tabeli Pracownicy (wszystkie atrybuty). ; b) Polecenie: Wyświetl dane (wszystkie

Bardziej szczegółowo

Konstruowanie Baz Danych SQL UNION, INTERSECT, EXCEPT

Konstruowanie Baz Danych SQL UNION, INTERSECT, EXCEPT Studia podyplomowe Inżynieria oprogramowania współfinansowane przez Unię Europejska w ramach Europejskiego Funduszu Społecznego Projekt Studia podyplomowe z zakresu wytwarzania oprogramowania oraz zarządzania

Bardziej szczegółowo

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

Programowanie w SQL. definicja bloku instrukcji BEGIN...END, warunkowe wykonanie instrukcji IF...ELSE, wyrażenie CASE, Programowanie w SQL definicja bloku instrukcji BEGIN...END, warunkowe wykonanie instrukcji IF...ELSE, wyrażenie CASE, kontynuacja działania od instrukcji za podaną etykietą GOTO etykieta, wyjście bezwarunkowe

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

SQL w praktyce. Miłej i owocnej nauki!!!

SQL w praktyce. Miłej i owocnej nauki!!! SQL w praktyce Niniejsza praca objęta jest prawami autorskimi. Nielegalne jest kopiowanie żadnej częsci tej pracy w żadnej postaci. Niezgodne z prawem tym bardziej jest udostępnianie innym tej pracy odpłatnie

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

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

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

Obiektowe bazy danych Ćwiczenia laboratoryjne (?)

Obiektowe bazy danych Ćwiczenia laboratoryjne (?) Obiektowe bazy danych Ćwiczenia laboratoryjne (?) Tworzenie typów obiektowych 1. Zdefiniuj typ obiektowy reprezentujący SAMOCHODY. Każdy samochód powinien mieć markę, model, liczbę kilometrów oraz datę

Bardziej szczegółowo

Wykład 7 Implementacja języka SQL w systemach baz danych Oracle sortowanie, funkcje agregujące i podzapytania.

Wykład 7 Implementacja języka SQL w systemach baz danych Oracle sortowanie, funkcje agregujące i podzapytania. Wykład 7 Implementacja języka SQL w systemach baz danych Oracle sortowanie, funkcje agregujące i podzapytania. Przykładowa RBD o schematach relacji (tzw. płaska postać RBD): N(PRACOWNICY) = {ID_P, IMIĘ,

Bardziej szczegółowo

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

KOLEKCJE - to typy masowe,zawierające pewną liczbę jednorodnych elementów KOLEKCJE - to typy masowe,zawierające pewną liczbę jednorodnych elementów SQL3 wprowadza następujące kolekcje: zbiory ( SETS ) - zestaw elementów bez powtórzeń, kolejność nieistotna listy ( LISTS ) - zestaw

Bardziej szczegółowo

Ref. 7 - Język SQL - polecenia DDL i DML

Ref. 7 - Język SQL - polecenia DDL i DML Ref. 7 - Język SQL - polecenia DDL i DML Wprowadzenie do języka SQL. Polecenia generujące strukturę bazy danych: CREATE, ALTER i DROP. Polecenia: wprowadzające dane do bazy - INSERT, modyfikujące zawartość

Bardziej szczegółowo

PROJEKTOWANIE BAZ DANYCH

PROJEKTOWANIE BAZ DANYCH Uniwersytet Przyrodniczy w Poznaniu - Instytut Inżynierii Biosystemów - Zakład Informatyki Stosowanej PROJEKTOWANIE BAZ DANYCH Ćwiczenia T-SQL - SQL Server 2008 / 2012 Prowadzący: dr inż. Radosław J. Kozłowski

Bardziej szczegółowo

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

Język DML. Instrukcje DML w różnych implementacjach SQL są bardzo podobne. Podstawowymi instrukcjami DML są: SELECT INSERT UPDATE DELETE Język DML Instrukcje DML w różnych implementacjach SQL są bardzo podobne. Podstawowymi instrukcjami DML są: SELECT INSERT UPDATE DELETE Systemy Baz Danych, Hanna Kleban 1 INSERT Instrukcja INSERT dodawanie

Bardziej szczegółowo

strukturalny język zapytań używany do tworzenia i modyfikowania baz danych oraz do umieszczania i pobierania danych z baz danych

strukturalny język zapytań używany do tworzenia i modyfikowania baz danych oraz do umieszczania i pobierania danych z baz danych SQL SQL (ang. Structured Query Language): strukturalny język zapytań używany do tworzenia strukturalny język zapytań używany do tworzenia i modyfikowania baz danych oraz do umieszczania i pobierania danych

Bardziej szczegółowo

Systemy GIS Tworzenie zapytań w bazach danych

Systemy GIS Tworzenie zapytań w bazach danych Systemy GIS Tworzenie zapytań w bazach danych Wykład nr 6 Analizy danych w systemach GIS Jak pytać bazę danych, żeby otrzymać sensowną odpowiedź......czyli podstawy języka SQL INSERT, SELECT, DROP, UPDATE

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

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

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

BAZY DANYCH. CREATE TABLE dbo.wydzialy (ID INT, Akronim VARCHAR(4) NOT NULL, Wydzial VARCHAR(30) NOT NULL, CONSTRAINT Kluczyk PRIMARY KEY(ID) )

BAZY DANYCH. CREATE TABLE dbo.wydzialy (ID INT, Akronim VARCHAR(4) NOT NULL, Wydzial VARCHAR(30) NOT NULL, CONSTRAINT Kluczyk PRIMARY KEY(ID) ) BAZY DANYCH laboratorium 3 tworzenie, modyfikacje i usuwanie tabel, operacje na danych Cel Stworzenie w ramach bazy danych Biblioteka nowych tabel według specyfikacji (CREATE TABLE Ustawianie właściwości

Bardziej szczegółowo

Część 1: OLAP. Raport z zajęć laboratoryjnych w ramach przedmiotu Hurtownie i eksploracja danych

Część 1: OLAP. Raport z zajęć laboratoryjnych w ramach przedmiotu Hurtownie i eksploracja danych Łukasz Przywarty 171018 Wrocław, 05.12.2012 r. Grupa: CZW/N 10:00-13:00 Raport z zajęć laboratoryjnych w ramach przedmiotu Hurtownie i eksploracja danych Część 1: OLAP Prowadzący: dr inż. Henryk Maciejewski

Bardziej szczegółowo

Lista zadań nr 1. 4. Wyświetlić imię i nazwisko dla każdego pracownika z departamentu DEP T NO o numerze 000.

Lista zadań nr 1. 4. Wyświetlić imię i nazwisko dla każdego pracownika z departamentu DEP T NO o numerze 000. Lista zadań nr 1 Zapytania SQL, SELECT z klauzulą WHERE i ORDER BY 1. Wyświetlić zawartość tablicy z pracownikami (EMPLOYEE). 2. Wyświetlić nazwisko i imię LAST NAME, F IRST NAME dla każdego pracownika.

Bardziej szczegółowo

Język SQL. instrukcja laboratoryjna. Politechnika Śląska Instytut Informatyki. laboratorium Bazy Danych

Język SQL. instrukcja laboratoryjna. Politechnika Śląska Instytut Informatyki. laboratorium Bazy Danych Politechnika Śląska Instytut Informatyki instrukcja laboratoryjna laboratorium Bazy Danych przygotowali: mgr inż. Paweł Kasprowski (Kasprowski@zti.iinf.polsl.gliwice.pl) mgr inż. Bożena Małysiak (bozena@ivp.iinf.polsl.gliwice.pl)

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

Języki programowania wysokiego poziomu. PHP cz.4. Bazy danych

Języki programowania wysokiego poziomu. PHP cz.4. Bazy danych Języki programowania wysokiego poziomu PHP cz.4. Bazy danych PHP i bazy danych PHP może zostać rozszerzony o mechanizmy dostępu do różnych baz danych: MySQL moduł mysql albo jego nowsza wersja mysqli (moduł

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

Struktura bazy danych

Struktura bazy danych Bazy danych - MySQL Warunki zaliczenia tych zajęć Rozwiązania zadań domowych proszę zapisać do pliku o nazwie Bazy danych i wysłać do mnie jako załącznik. Ostateczny termin: niedziela, 9.06, godzina 24:00.

Bardziej szczegółowo

- język zapytań służący do zapisywania wyrażeń relacji, modyfikacji relacji, tworzenia relacji

- język zapytań służący do zapisywania wyrażeń relacji, modyfikacji relacji, tworzenia relacji 6. Język SQL Język SQL (Structured Query Language): - język zapytań służący do zapisywania wyrażeń relacji, modyfikacji relacji, tworzenia relacji - stworzony w IBM w latach 70-tych DML (Data Manipulation

Bardziej szczegółowo

Elementy. języka SQL

Elementy. języka SQL Elementy języka SQL SQL SQL - Structured Query Language język czwartej generacji (4GL), opracowany w latach 70-tych przez IBM strukturalny język zapytań, przeznaczony do definiowania, wyszukiwania i administrowania

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 kwerendy (moduł 5) 1. Przekopiuj na dysk F:\ bazę M5KW.mdb z dysku wskazanego przez prowadzącego

Bazy danych kwerendy (moduł 5) 1. Przekopiuj na dysk F:\ bazę M5KW.mdb z dysku wskazanego przez prowadzącego Bazy danych kwerendy (moduł 5) 1. Przekopiuj na dysk F:\ bazę M5KW.mdb z dysku wskazanego przez prowadzącego 2. Otwórz bazę (F:\M5KW) 3. Zapoznaj się ze strukturą bazy (tabele, relacje) 4. Wykorzystując

Bardziej szczegółowo

w PL/SQL bloki nazwane to: funkcje, procedury, pakiety, wyzwalacze

w PL/SQL bloki nazwane to: funkcje, procedury, pakiety, wyzwalacze w PL/SQL bloki nazwane to: funkcje, procedury, pakiety, wyzwalacze Cechy bloków nazwanych: w postaci skompilowanej trwale przechowywane na serwerze wraz z danymi wykonywane na żądanie użytkownika lub w

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

Program szkoleniowy Efektywni50+ Moduł IV Podstawy relacyjnych baz danych i język SQL

Program szkoleniowy Efektywni50+ Moduł IV Podstawy relacyjnych baz danych i język SQL Program szkoleniowy Efektywni50+ Moduł IV Podstawy relacyjnych baz danych i język SQL 1 Podstawy relacyjnego modelu danych. 3h UWAGA: Temat zajęć jest typowo teoretyczny i stanowi wprowadzenie do zagadnień

Bardziej szczegółowo

Bartosz Jachnik - Kino

Bartosz Jachnik - Kino Bartosz Jachnik - Kino I. Opis bazy Prezentowana baza danych stworzona została na potrzeby prowadzenia kina. Zawiera ona 8 tabel, które opisują filmy grane w danym okresie w kinie, wraz ze szczegółowym

Bardziej szczegółowo

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

Bazy danych wykład dwunasty PL/SQL, c.d. Konrad Zdanowski ( Uniwersytet Kardynała Stefana Bazy danych Wyszyńskiego, wykładwarszawa) Bazy danych wykład dwunasty PL/SQL, c.d. Konrad Zdanowski Uniwersytet Kardynała Stefana Wyszyńskiego, Warszawa dwunasty PL/SQL, c.d. 1 / 37 SQL to za mało SQL brakuje możliwości dostępnych w językach proceduralnych.

Bardziej szczegółowo

Bazy danych. Plan wykładu. Zależności funkcyjne. Wykład 2: Relacyjny model danych - zależności funkcyjne. Podstawy SQL.

Bazy danych. Plan wykładu. Zależności funkcyjne. Wykład 2: Relacyjny model danych - zależności funkcyjne. Podstawy SQL. Plan wykładu Bazy danych Wykład 2: Relacyjny model danych - zależności funkcyjne. Podstawy SQL. Deficja zależności funkcyjnych Klucze relacji Reguły dotyczące zależności funkcyjnych Domknięcie zbioru atrybutów

Bardziej szczegółowo

DECLARE typ [( )] [ NOT NULL ] [ { := DEFAULT } ];

DECLARE <nazwa_zmiennej> typ [(<rozmiar> )] [ NOT NULL ] [ { := DEFAULT } <wartość> ]; Braki w SQL obsługi zdarzeń i sytuacji wyjątkowych funkcji i procedur użytkownika definiowania złożonych ograniczeń integralnościowych Proceduralny SQL Transact- SQL używany przez Microsoft SQL Server

Bardziej szczegółowo

Fizyczna struktura bazy danych w SQL Serwerze

Fizyczna struktura bazy danych w SQL Serwerze Sposób przechowywania danych na dysku twardym komputera ma zasadnicze znaczenie dla wydajności całej bazy i jest powodem tworzenia między innymi indeksów. Fizyczna struktura bazy danych w SQL Serwerze

Bardziej szczegółowo

Projekt jest finansowany ze środków Unii Europejskiej, Europejskiego Funduszu Społecznego i budŝetu państwa. Studia Podyplomowe dla Nauczycieli

Projekt jest finansowany ze środków Unii Europejskiej, Europejskiego Funduszu Społecznego i budŝetu państwa. Studia Podyplomowe dla Nauczycieli Projekt jest finansowany ze środków Unii Europejskiej, Europejskiego Funduszu Społecznego i budŝetu państwa Studia Podyplomowe dla Nauczycieli Bazy danych SQL Języki baz danych Interfejs DBMS składa się

Bardziej szczegółowo

Kowalski Marcin 156439 Wrocław, dn. 3.06.2009 Jaśkiewicz Kamil 148592. Bazy Danych 1 Podstawy Projekt Temat: Baza danych do zarządzania projektami

Kowalski Marcin 156439 Wrocław, dn. 3.06.2009 Jaśkiewicz Kamil 148592. Bazy Danych 1 Podstawy Projekt Temat: Baza danych do zarządzania projektami Kowalski Marcin 156439 Wrocław, dn. 3.06.2009 Jaśkiewicz Kamil 148592 Bazy Danych 1 Podstawy Projekt Temat: Baza danych do zarządzania projektami Spis treści Założenia Projektowe...1 Schemat Bazy Danych...1

Bardziej szczegółowo

Baza danych hotel Maciej Gerus 258583

Baza danych hotel Maciej Gerus 258583 Baza danych hotel Maciej Gerus 258583 Baza ta składa się z 7 tabel (jak widać na rysunku) i pozwala wirtualnie zapisywać (oraz analizować) niektóre uproszczone elementy pracy przedsiębiorstwa oferującego

Bardziej szczegółowo

Wprowadzenie do JDBC z wykorzystaniem bazy H2

Wprowadzenie do JDBC z wykorzystaniem bazy H2 Wprowadzenie do JDBC z wykorzystaniem bazy H2 JDBC (ang. Java DataBase Connectivity). Biblioteka stanowiąca interfejs umożliwiający aplikacjom napisanym w języku Java porozumiewać się z bazami danych za

Bardziej szczegółowo

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

Bazy danych Język SQL część 2 Wykład dla studentów matem Bazy danych Język SQL część 2 Wykład dla studentów matematyki 21 marca 2015 Zapytania na kilku tabelach Czasem poszukiwana informacja znajduje się w kilku tabelach. Aby zapytanie dotyczyło kilku tabel,

Bardziej szczegółowo

Administracja i programowanie pod Microsoft SQL Server 2000

Administracja i programowanie pod Microsoft SQL Server 2000 Administracja i programowanie pod Paweł Rajba pawel@ii.uni.wroc.pl http://www.kursy24.eu/ Zawartość modułu 3 Podstawy programowania w T-SQL Zmienne i operatory Instrukcje sterujące Komunikaty Format daty

Bardziej szczegółowo

Zaawansowane bazy danych i hurtownie danych studia zaoczne II stopnia, sem. I

Zaawansowane bazy danych i hurtownie danych studia zaoczne II stopnia, sem. I Wydział Informatyki Politechnika Białostocka Plan wykładu Zaawansowane bazy danych i hurtownie danych studia zaoczne II stopnia, sem. I 1. MySQL 2. Powtórzenie SQL WYKŁAD 2: MySQL: podstawowe obiekty Powtórzenie

Bardziej szczegółowo

Technologie baz danych

Technologie baz danych Plan wykładu Technologie baz danych Wykład 2: Relacyjny model danych - zależności funkcyjne. SQL - podstawy Definicja zależności funkcyjnych Reguły dotyczące zależności funkcyjnych Domknięcie zbioru atrybutów

Bardziej szczegółowo

Szkolenie Oracle SQL podstawy. Terminy. 15 17 lutego 2010 First Minute! 1100zł!

Szkolenie Oracle SQL podstawy. Terminy. 15 17 lutego 2010 First Minute! 1100zł! Szkolenie Oracle SQL podstawy Terminy 15 17 lutego 2010 First Minute! 1100zł! Opis szkolenia Baza danych Oracle od dawna cieszy się zasłużona sławą wśród informatyków. Jej wydajność, szybkość działania

Bardziej szczegółowo

Bazy danych. Plan wykładu. Diagramy ER. Podstawy modeli relacyjnych. Podstawy modeli relacyjnych. Podstawy modeli relacyjnych

Bazy danych. Plan wykładu. Diagramy ER. Podstawy modeli relacyjnych. Podstawy modeli relacyjnych. Podstawy modeli relacyjnych Plan wykładu Bazy danych Wykład 9: Przechodzenie od diagramów E/R do modelu relacyjnego. Definiowanie perspektyw. Diagramy E/R - powtórzenie Relacyjne bazy danych Od diagramów E/R do relacji SQL - perspektywy

Bardziej szczegółowo

Bazy danych 2. Wykład 4 Structured Query Language (SQL)

Bazy danych 2. Wykład 4 Structured Query Language (SQL) Bazy danych 2 Wykład 4 Structured Query Language (SQL) Cechy SQL W standardzie SQL wyróŝnia się dwie części: DDL (Data Definition Language) - język definiowania danych DML (Data Manipulation Language)

Bardziej szczegółowo

Zaawansowane bazy danych i hurtownie danych semestr I

Zaawansowane bazy danych i hurtownie danych semestr I Podprogramy Wydział Informatyki Politechnika Białostocka Zaawansowane bazy danych i hurtownie danych semestr I Procedury do przeprowadzenia akcji Funkcje do obliczania wartości Pakiety do zbierania logicznie

Bardziej szczegółowo

Wykład 2. SQL 1 Structured Query Lenguage

Wykład 2. SQL 1 Structured Query Lenguage Wykład 2 SQL 1 Structured Query Lenguage SQL (Structured Query Language) Język zapytań do bazy danych. IBM lata osiemdziesiąte. Stosowany w systemach zarządzania bazami danych (DBMS); Oracle, Paradox,Access,

Bardziej szczegółowo

Wprowadzenie do języka SQL

Wprowadzenie do języka SQL Wprowadzenie do języka SQL język dostępu do bazy danych grupy poleceń języka: DQL (ang( ang.. Data Query Language) DML (ang( ang.. Data Manipulation Language) DDL (ang( ang.. Data Definition Language)

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

Laboratorium nr 8. Temat: Podstawy języka zapytań SQL (część 2)

Laboratorium nr 8. Temat: Podstawy języka zapytań SQL (część 2) Laboratorium nr 8 Temat: Podstawy języka zapytań SQL (część 2) PLAN LABORATORIUM: 1. Sortowanie. 2. Warunek WHERE 3. Eliminacja powtórzeń - DISTINCT. 4. WyraŜenia: BETWEEN...AND, IN, LIKE, IS NULL. 5.

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

z przedmiotu: Techniki Informatyczne Stanisław Flaga (stanislaw.flaga@agh.edu.pl)

z przedmiotu: Techniki Informatyczne Stanisław Flaga (stanislaw.flaga@agh.edu.pl) mysql relacyjna baza danych wstęp Materiały pomocnicze do laboratorium z przedmiotu: Techniki Informatyczne Stanisław Flaga () Wydział Inżynierii Mechanicznej i Robotyki Katedra Automatyzacji Procesów

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

Systemy internetowe. Wykład 4 mysql. West Pomeranian University of Technology, Szczecin; Faculty of Computer Science

Systemy internetowe. Wykład 4 mysql. West Pomeranian University of Technology, Szczecin; Faculty of Computer Science Systemy internetowe Wykład 4 mysql MySQL - wstęp SZBD: komercyjne: Microsoft SQL Server, Oracle, DB2... darmowe: MySQL, PostgreSQL, Firebird... MySQL darmowy (użytek niekomercyjny) Wady: niska wydajność

Bardziej szczegółowo

Bazy Danych i Usługi Sieciowe

Bazy Danych i Usługi Sieciowe Bazy Danych i Usługi Sieciowe Ćwiczenia I Paweł Daniluk Wydział Fizyki Jesień 2011 P. Daniluk (Wydział Fizyki) BDiUS ćw. I Jesień 2011 1 / 15 Strona wykładu http://bioexploratorium.pl/wiki/ Bazy_Danych_i_Usługi_Sieciowe_-_2011z

Bardziej szczegółowo

Administracja i programowanie pod Microsoft SQL Server 2000

Administracja i programowanie pod Microsoft SQL Server 2000 Administracja i programowanie pod Paweł Rajba pawel@ii.uni.wroc.pl http://www.kursy24.eu/ Zawartość modułu 7 Indeksy Wprowadzenie Rodzaje indeksów Wybór indeksów wybór indeksu zgrupowanego Tworzenie, usuwanie

Bardziej szczegółowo