Facebook - konwersja
Czytaj fragment
Pobierz fragment

  • Empik Go W empik go

SQL w jeden dzień. Praktyczny kurs języka SQL - ebook

Wydawnictwo:
Data wydania:
2 października 2024
Format ebooka:
EPUB
Format EPUB
czytaj
na czytniku
czytaj
na tablecie
czytaj
na smartfonie
Jeden z najpopularniejszych formatów e-booków na świecie. Niezwykle wygodny i przyjazny czytelnikom - w przeciwieństwie do formatu PDF umożliwia skalowanie czcionki, dzięki czemu możliwe jest dopasowanie jej wielkości do kroju i rozmiarów ekranu. Więcej informacji znajdziesz w dziale Pomoc.
Multiformat
E-booki w Virtualo.pl dostępne są w opcji multiformatu. Oznacza to, że po dokonaniu zakupu, e-book pojawi się na Twoim koncie we wszystkich formatach dostępnych aktualnie dla danego tytułu. Informacja o dostępności poszczególnych formatów znajduje się na karcie produktu.
, PDF
Format PDF
czytaj
na laptopie
czytaj
na tablecie
Format e-booków, który możesz odczytywać na tablecie oraz laptopie. Pliki PDF są odczytywane również przez czytniki i smartfony, jednakze względu na komfort czytania i brak możliwości skalowania czcionki, czytanie plików PDF na tych urządzeniach może być męczące dla oczu. Więcej informacji znajdziesz w dziale Pomoc.
Multiformat
E-booki w Virtualo.pl dostępne są w opcji multiformatu. Oznacza to, że po dokonaniu zakupu, e-book pojawi się na Twoim koncie we wszystkich formatach dostępnych aktualnie dla danego tytułu. Informacja o dostępności poszczególnych formatów znajduje się na karcie produktu.
(2w1)
Multiformat
E-booki sprzedawane w księgarni Virtualo.pl dostępne są w opcji multiformatu - kupujesz treść, nie format. Po dodaniu e-booka do koszyka i dokonaniu płatności, e-book pojawi się na Twoim koncie w Mojej Bibliotece we wszystkich formatach dostępnych aktualnie dla danego tytułu. Informacja o dostępności poszczególnych formatów znajduje się na karcie produktu przy okładce. Uwaga: audiobooki nie są objęte opcją multiformatu.
czytaj
na laptopie
Pliki PDF zabezpieczone watermarkiem możesz odczytać na dowolnym laptopie po zainstalowaniu czytnika dokumentów PDF. Najpowszechniejszym programem, który umożliwi odczytanie pliku PDF na laptopie, jest Adobe Reader. W zależności od potrzeb, możesz zainstalować również inny program - e-booki PDF pod względem sposobu odczytywania nie różnią niczym od powszechnie stosowanych dokumentów PDF, które odczytujemy każdego dnia.
Informacje na temat zabezpieczenia e-booka znajdziesz na karcie produktu w "Szczegółach na temat e-booka". Więcej informacji znajdziesz w dziale Pomoc.
czytaj
na tablecie
Aby odczytywać e-booki na swoim tablecie musisz zainstalować specjalną aplikację. W zależności od formatu e-booka oraz systemu operacyjnego, który jest zainstalowany na Twoim urządzeniu może to być np. Bluefire dla EPUBa lub aplikacja Kindle dla formatu MOBI.
Informacje na temat zabezpieczenia e-booka znajdziesz na karcie produktu w "Szczegółach na temat e-booka". Więcej informacji znajdziesz w dziale Pomoc.
czytaj
na czytniku
Czytanie na e-czytniku z ekranem e-ink jest bardzo wygodne i nie męczy wzroku. Pliki przystosowane do odczytywania na czytnikach to przede wszystkim EPUB (ten format możesz odczytać m.in. na czytnikach PocketBook) i MOBI (ten fromat możesz odczytać m.in. na czytnikach Kindle).
Informacje na temat zabezpieczenia e-booka znajdziesz na karcie produktu w "Szczegółach na temat e-booka". Więcej informacji znajdziesz w dziale Pomoc.
czytaj
na smartfonie
Aby odczytywać e-booki na swoim smartfonie musisz zainstalować specjalną aplikację. W zależności od formatu e-booka oraz systemu operacyjnego, który jest zainstalowany na Twoim urządzeniu może to być np. iBooks dla EPUBa lub aplikacja Kindle dla formatu MOBI.
Informacje na temat zabezpieczenia e-booka znajdziesz na karcie produktu w "Szczegółach na temat e-booka". Więcej informacji znajdziesz w dziale Pomoc.
Czytaj fragment
Pobierz fragment

SQL w jeden dzień. Praktyczny kurs języka SQL - ebook

Odkryj moc SQL w rekordowym tempie! Ta wyjątkowa książka oferuje intensywny kurs, który pozwoli Ci opanować podstawy i zaawansowane techniki SQL w jeden dzień. To prawdziwa skarbnica wiedzy! Każda strona jest nasycona esencjonalną wiedzą, którą natychmiast przełożysz na praktykę. Od prostych zapytań SELECT po złożone operacje i optymalizację wydajności. Naucz się tworzyć efektywne zapytania, projektować wydajne schematy baz danych i optymalizować systemy. Zdobyta wiedza pozwoli Ci swobodnie poruszać się w świecie relacyjnych baz danych. Książka jest pełna praktycznych przykładów, które pomogą Ci zrozumieć zastosowanie SQL w realnych scenariuszach biznesowych. Niezależnie od Twojego poziomu zaawansowania, znajdziesz tu materiał dostosowany do swoich potrzeb. Zainwestuj jeden dzień, a zyskasz umiejętności na całe życie zawodowe. Nie czekaj - rozpocznij swoją przygodę z SQL już teraz i przekonaj się, jak wiele możesz osiągnąć w tak krótkim czasie!

Kategoria: Bazy danych
Zabezpieczenie: Watermark
Watermark
Watermarkowanie polega na znakowaniu plików wewnątrz treści, dzięki czemu możliwe jest rozpoznanie unikatowej licencji transakcyjnej Użytkownika. E-książki zabezpieczone watermarkiem można odczytywać na wszystkich urządzeniach odtwarzających wybrany format (czytniki, tablety, smartfony). Nie ma również ograniczeń liczby licencji oraz istnieje możliwość swobodnego przenoszenia plików między urządzeniami. Pliki z watermarkiem są kompatybilne z popularnymi programami do odczytywania ebooków, jak np. Calibre oraz aplikacjami na urządzenia mobilne na takie platformy jak iOS oraz Android.
ISBN: 9788368316056
Rozmiar pliku: 132 KB

FRAGMENT KSIĄŻKI

Spis treści

1. Dlaczego SQL jest ważny?

1.1. Rola SQL w nowoczesnym rozwoju oprogramowania

1.2. Porównanie SQL z innymi technologiami

1.3. Szybki start: Pierwsze zapytanie SELECT

2. Podstawy: Struktura bazy i typy danych

2.1. Tabele, kolumny i wiersze

2.2. Klucze podstawowe i obce

2.3. Najważniejsze typy danych SQL i ich zastosowanie

2.4. Praktyka: Projektowanie prostej schematu bazy danych

3. Tworzenie i modyfikacja tabel

3.1. Składnia CREATE TABLE z przykładami

3.2. Dodawanie, modyfikacja i usuwanie kolumn za pomocą ALTER TABLE

3.3. Usuwanie tabel z DROP TABLE

3.4. Ćwiczenie: Stwórz schemat bazy danych dla sklepu internetowego

4. Wstawianie danych: INSERT INTO

4.1. Podstawowa składnia INSERT INTO

4.2. Wstawianie wielu wierszy jednocześnie

4.3. INSERT INTO SELECT: Kopiowanie danych między tabelami

4.4. Praktyka: Wypełnianie tabel sklepu internetowego danymi

5. Pobieranie danych: SELECT i klauzula WHERE

5.1. Anatomia zapytania SELECT

5.2. Filtrowanie z WHERE: operatory porównania i logiczne

5.3. Zaawansowane filtrowanie: LIKE, IN, BETWEEN

5.4. Ćwiczenie: Tworzenie raportów dla sklepu internetowego

6. Agregacja danych: GROUP BY i funkcje agregujące

6.1. Funkcje COUNT, SUM, AVG, MAX, MIN

6.2. Grupowanie wyników z GROUP BY

6.3. Filtrowanie grup z HAVING

6.4. Ćwiczenie: Analiza sprzedaży w sklepie internetowym

7. Modyfikacja i usuwanie danych: UPDATE i DELETE

7.1. Składnia UPDATE z przykładami

7.2. Masowe aktualizacje z JOIN

7.3. Bezpieczne usuwanie z DELETE

7.4. Praktyka: Aktualizacja cen i usuwanie nieaktualnych produktów

8. Indeksy: Optymalizacja wydajności zapytań

8.1. Tworzenie indeksów: składnia CREATE INDEX

8.2. Typy indeksów i kiedy ich używać

8.3. Analiza planu wykonania zapytania

8.4. Ćwiczenie: Optymalizacja zapytań w sklepie internetowym

9. Widoki i procedury składowane: Reużywalność kodu SQL

9.1. Tworzenie widoków dla często używanych zapytań

9.2. Pisanie i wywoływanie procedur składowanych

9.3. Funkcje zdefiniowane przez użytkownika

9.4. Ćwiczenie: Tworzenie raportów i automatyzacja procesów

10. Najczęstsze pułapki i jak ich unikać

10.1. Problemy z wydajnością: N+1 zapytania

10.2. Nieprawidłowe używanie indeksów

10.3. Błędy w złączeniach tabel

10.4. Ćwiczenie: Debugowanie i optymalizacja problematycznych zapytań

11. Narzędzia i zasoby do dalszej nauki

11.1. Popularne systemy zarządzania bazami danych: MySQL, PostgreSQL, SQLite

11.2. Narzędzia do wizualizacji i projektowania baz danych

11.3. Platformy online do ćwiczenia SQL

11.4. Rekomendowane książki i kursy online1.1. Rola SQL w nowoczesnym rozwoju oprogramowania

1.1. Rola SQL w nowoczesnym rozwoju oprogramowania

SQL (Structured Query Language) to język programowania stworzony do zarządzania i manipulowania relacyjnymi bazami danych. Jego główne zastosowania obejmują:

- Tworzenie, modyfikowanie i usuwanie struktur baz danych
- Wstawianie, aktualizowanie i usuwanie danych
- Pobieranie informacji z baz danych
- Zarządzanie uprawnieniami i kontrolą dostępu do danych

Bazy danych są fundamentem większości nowoczesnych aplikacji. Znajdziesz je w:

- Aplikacjach internetowych
- Systemach zarządzania treścią
- Aplikacjach mobilnych
- Systemach analitycznych
- Platformach e-commerce
- Systemach zarządzania relacjami z klientami (CRM)

Używanie SQL w projektach programistycznych przynosi liczne korzyści:

- Efektywne przechowywanie i zarządzanie dużymi ilościami danych
- Szybkie i precyzyjne wyszukiwanie informacji
- Zapewnienie integralności i spójności danych
- Łatwe skalowanie aplikacji wraz ze wzrostem ilości danych
- Możliwość tworzenia zaawansowanych raportów i analiz
- Standaryzacja dostępu do danych w różnych systemach i językach programowania
- Optymalizacja wydajności aplikacji poprzez efektywne zapytania do bazy danych

SQL można łatwo zintegrować z większością popularnych języków programowania:

- Języki oferują biblioteki i sterowniki do komunikacji z bazami danych
- Zapytania SQL można osadzać bezpośrednio w kodzie aplikacji
- Istnieją ORM (Object-Relational Mapping) ułatwiające pracę z bazami danych
- API bazodanowe umożliwiają abstrakcję niskopoziomowych operacji SQL

Aplikacje oparte na SQL charakteryzują się wysoką skalowalnością i wydajnością:

- Indeksy i optymalizacja zapytań poprawiają szybkość dostępu do danych
- Mechanizmy buforowania zmniejszają obciążenie bazy danych
- Partycjonowanie danych umożliwia efektywne zarządzanie dużymi zbiorami
- Replikacja i klastrowanie zapewniają wysoką dostępność i odporność na awarie
- Transakcje gwarantują spójność danych przy równoczesnym dostępie

SQL oferuje wysoki poziom standaryzacji i przenośności:

- Podstawowa składnia SQL jest wspólna dla większości systemów bazodanowych
- Zapytania można łatwo przenosić między różnymi bazami danych
- Standard ANSI SQL zapewnia kompatybilność między systemami
- Migracja danych między różnymi bazami jest stosunkowo prosta
- Umiejętności SQL są uniwersalne i przydatne w różnych środowiskach

SQL odgrywa kluczową rolę w analizie danych i Business Intelligence:

- Umożliwia tworzenie złożonych zapytań analitycznych
- Wspiera agregację danych i funkcje statystyczne
- Pozwala na łączenie danych z wielu źródeł poprzez operacje JOIN
- Ułatwia generowanie raportów i dashboardów
- Wspiera tworzenie widoków i procedur do cyklicznych analiz
- Umożliwia eksplorację danych i odkrywanie ukrytych wzorców

W kontekście Big Data i przetwarzania w czasie rzeczywistym:

- SQL adaptuje się do pracy z ogromnymi zbiorami danych
- Wspiera przetwarzanie strumieniowe dla analiz w czasie rzeczywistym
- Integruje się z narzędziami do przetwarzania rozproszonych danych
- Pozwala na tworzenie zapytań na danych strukturalnych i niestrukturalnych
- Umożliwia optymalizację wydajności dla bardzo dużych wolumenów danych
- Wspiera paralelizację zapytań dla szybszego przetwarzania

Przyszłość SQL w erze chmury i mikrousług:

- SQL adaptuje się do modeli chmurowych, oferując elastyczność i skalowalność
- Bazy SQL as a Service stają się coraz popularniejsze
- SQL integruje się z architekturami mikrousługowymi
- Rozwój SQL wspiera przetwarzanie danych na krawędzi sieci
- Ewolucja SQL w kierunku obsługi danych nierelacyjnych i semi-strukturalnych
- Automatyzacja zarządzania bazami SQL w środowiskach chmurowych
- Rozwój narzędzi do monitorowania i optymalizacji wydajności SQL w chmurze1.2. Porównanie SQL z innymi technologiami

Główne cechy SQL jako języka zapytań relacyjnych:

- Deklaratywność - opisujesz co chcesz osiągnąć, nie jak to zrobić
- Standaryzacja - wspólna podstawowa składnia dla różnych systemów
- Wsparcie dla złożonych zapytań i operacji na danych
- Możliwość łączenia danych z wielu tabel
- Wbudowane funkcje agregujące i analityczne
- Obsługa transakcji i zapewnienie integralności danych
- Kontrola dostępu i zarządzanie uprawnieniami
- Optymalizacja zapytań przez system zarządzania bazą danych

Struktura danych w bazach SQL:

- Tabele jako podstawowe jednostki przechowywania danych
- Wiersze reprezentujące pojedyncze rekordy lub encje
- Kolumny definiujące atrybuty lub właściwości danych
- Klucze główne do unikalnej identyfikacji rekordów
- Klucze obce do tworzenia relacji między tabelami
- Indeksy dla optymalizacji wyszukiwania
- Widoki jako wirtualne tabele dla często używanych zapytań
- Schematy do organizacji i grupowania obiektów bazodanowych

Typy operacji CRUD w SQL:

- Create (tworzenie) - dodawanie nowych rekordów do bazy danych
- Read (odczyt) - pobieranie danych z bazy za pomocą zapytań SELECT
- Update (aktualizacja) - modyfikowanie istniejących rekordów
- Delete (usuwanie) - usuwanie rekordów z bazy danych
- Operacje INSERT do dodawania nowych danych
- Zapytania SELECT do pobierania i filtrowania informacji
- Polecenia UPDATE do zmiany wartości w istniejących rekordach
- Instrukcje DELETE do usuwania niepotrzebnych danych

Bazy NoSQL:

- Dokumentowe: przechowują dane w elastycznych strukturach podobnych do JSON
- Klucz-wartość: proste magazyny danych oparte na unikalnych kluczach
- Kolumnowe: optymalizowane do przechowywania i analizy dużych ilości danych
- Grafowe: specjalizują się w reprezentacji i analizie relacji między danymi

Główne różnice między SQL a NoSQL:

- Struktura danych: SQL - sztywna, tabelaryczna; NoSQL - elastyczna, zależna od typu
- Schema: SQL - zdefiniowana z góry; NoSQL - często schema-less lub elastyczna
- Skalowalność: SQL - głównie wertykalna; NoSQL - często horyzontalna
- Spójność danych: SQL - silna; NoSQL - często eventual consistency
- Złożoność zapytań: SQL - zaawansowane zapytania; NoSQL - prostsze operacje
- Transakcje: SQL - pełne wsparcie ACID; NoSQL - różny poziom wsparcia
- Normalizacja: SQL - wysoki poziom; NoSQL - często denormalizacja
- Relacje: SQL - wbudowane; NoSQL - często symulowane lub w przypadku baz grafowych

Scenariusze użycia SQL vs NoSQL:

- SQL: • Aplikacje wymagające złożonych transakcji i integralności danych • Systemy raportowania i analizy biznesowej • Aplikacje z jasno zdefiniowaną strukturą danych • Systemy finansowe i bankowe • Tradycyjne systemy zarządzania treścią
- NoSQL: • Aplikacje z dużą ilością danych i wysokim obciążeniem • Systemy przetwarzające dane w czasie rzeczywistym • Aplikacje wymagające elastycznej struktury danych • Platformy społecznościowe i aplikacje mobilne • Systemy IoT i analiza logów • Magazyny danych dla mikrousług

Hybrydowe podejścia: łączenie SQL i NoSQL w projektach:

- Wykorzystanie SQL do krytycznych danych wymagających integralności
- Użycie NoSQL dla danych o zmiennej strukturze lub wymagających szybkiego dostępu
- Synchronizacja danych między systemami SQL i NoSQL
- Wykorzystanie SQL jako głównego magazynu z NoSQL jako cache
- Implementacja mikrousług z różnymi bazami danych dla różnych funkcji
- Użycie SQL do raportowania i analiz, NoSQL do gromadzenia surowych danych
- Integracja danych z różnych źródeł za pomocą narzędzi ETL

Ewolucja SQL w kierunku obsługi danych nierelacyjnych:

- Wprowadzenie typów danych JSON i XML w bazach relacyjnych
- Rozwój funkcji do przetwarzania i analizy danych semi-strukturalnych
- Implementacja indeksów dla danych nierelacyjnych w bazach SQL
- Wsparcie dla przechowywania i zapytywania danych geograficznych
- Rozszerzenia SQL do obsługi grafów i analiz sieciowych
- Rozwój funkcji analitycznych do przetwarzania dużych zbiorów danych
- Integracja z zewnętrznymi systemami przetwarzania danych

Trendy w rozwoju technologii bazodanowych:

- Wzrost popularności rozwiązań chmurowych i DBaaS (Database as a Service)
- Rozwój baz danych zaprojektowanych dla środowisk kontenerowych
- Zwiększenie nacisku na automatyzację zarządzania i optymalizacji baz danych
- Integracja machine learning w zarządzaniu i optymalizacji zapytań
- Rozwój systemów multi-model łączących różne paradygmaty bazodanowe
- Zwiększenie wsparcia dla przetwarzania strumieniowego i analiz w czasie rzeczywistym
- Rozwój technologii zapewniających większą skalowalność i odporność na awarie
- Nacisk na bezpieczeństwo i zgodność z regulacjami dotyczącymi ochrony danych
- Ewolucja w kierunku baz danych edge computing dla IoT i aplikacji rozproszonych

1.3. Szybki start: Pierwsze zapytanie SELECT

Struktura podstawowego zapytania SELECT:

- Słowo kluczowe SELECT rozpoczynające zapytanie
- Lista kolumn, które chcemy wybrać
- Słowo kluczowe FROM wskazujące tabelę źródłową
- Opcjonalna klauzula WHERE do filtrowania wyników
- Średnik (;) na końcu zapytania w większości systemów bazodanowych

Wybieranie kolumn z tabeli:

- Nazwy kolumn oddzielone przecinkami po słowie SELECT
- Możliwość wyboru dowolnej liczby kolumn
- Kolejność kolumn w zapytaniu określa kolejność w wynikach
- Możliwość używania aliasów dla kolumn za pomocą słowa AS
- Nazwy kolumn są zazwyczaj case-insensitive, ale najlepiej zachować konsystencję
- Możliwość używania funkcji na kolumnach, np. UPPER() dla tekstu

Użycie gwiazdki (\*) do wyboru wszystkich kolumn:

- Symbol \* zastępuje listę wszystkich kolumn w tabeli
- Pozwala na szybkie pobranie całej zawartości tabeli
- Użyteczne podczas eksploracji danych lub debugowania
- Może wpływać na wydajność przy dużych tabelach
- Nie zalecane w kodzie produkcyjnym ze względu na potencjalne zmiany struktury tabeli
- Lepiej jawnie wymieniać potrzebne kolumny w zapytaniach aplikacyjnych

Filtrowanie wyników za pomocą WHERE:

- Klauzula WHERE umieszczana po FROM w zapytaniu
- Określa warunki, które muszą spełniać zwracane wiersze
- Można łączyć wiele warunków za pomocą operatorów AND i OR
- Pozwala na precyzyjne zawężanie wyników zapytania
- Wspiera porównania z wartościami stałymi lub innymi kolumnami
- Możliwość używania funkcji w warunkach WHERE
- Warunki mogą odnosić się do dowolnych kolumn, nie tylko tych w SELECT

Proste operatory porównania:

- \= równe
- < mniejsze niż
- > większe niż

- <= mniejsze lub równe
- > \= większe lub równe

- <> lub != różne od
- Operatory działają na liczbach, tekście i datach
- Dla tekstu porównanie jest zazwyczaj case-insensitive
- Przy porównywaniu dat należy zwrócić uwagę na format
- Można używać IS NULL do sprawdzania wartości null

Sortowanie wyników za pomocą ORDER BY:

- Klauzula ORDER BY umieszczana na końcu zapytania
- Pozwala określić kolejność zwracanych wierszy
- Można sortować po jednej lub wielu kolumnach
- Domyślne sortowanie jest rosnące (ASC)
- Użyj DESC dla sortowania malejącego
- Możliwość sortowania po kolumnach nieuwzględnionych w SELECT
- Sortowanie może wpływać na wydajność przy dużych zbiorach danych
- Można sortować po wyrażeniach, np. ORDER BY LENGTH(nazwa)

Praktyczne przykłady prostych zapytań SELECT:

- SELECT imie, nazwisko FROM pracownicy;
- SELECT \* FROM produkty WHERE cena < 100;
- SELECT nazwa, data\_zamowienia FROM zamowienia ORDER BY data\_zamowienia DESC;
- SELECT DISTINCT kategoria FROM produkty;
- SELECT imie, nazwisko FROM klienci WHERE miasto = 'Warszawa';
- SELECT tytul, autor FROM ksiazki WHERE rok\_wydania >= 2000 AND rok\_wydania <= 2020;
- SELECT nazwa\_produktu, cena \* 1.23 AS cena\_z\_vat FROM produkty;
- SELECT imie, nazwisko FROM pracownicy WHERE data\_zatrudnienia IS NOT NULL;

Typowe błędy początkujących i jak ich unikać:

- Zapominanie o średniku na końcu zapytania - zawsze kończyć średnikiem
- Używanie pojedynczego cudzysłowu dla nazw kolumn - używać podwójnych cudzysłowów lub backticks
- Mieszanie AND i OR bez nawiasów - używać nawiasów dla jasności priorytetów
- Zapominanie o apostrofach dla wartości tekstowych - zawsze otaczać teksty apostrofami
- Próba używania aliasów kolumn w WHERE - aliasy działają tylko w ORDER BY i później
- Używanie \* w produkcyjnych zapytaniach - zawsze wymieniać potrzebne kolumny
- Nieprawidłowa kolejność klauzul - pamiętać o kolejności SELECT, FROM, WHERE, ORDER BY
- Literówki w nazwach tabel lub kolumn - dokładnie sprawdzać nazwy

Narzędzia do wykonywania zapytań SQL:

- Konsole terminalowe specyficzne dla danego systemu bazodanowego
- Graficzne interfejsy dostarczane przez producentów baz danych
- Uniwersalne narzędzia jak DBeaver, HeidiSQL czy MySQL Workbench
- Zintegrowane środowiska programistyczne (IDE) z wtyczkami do baz danych
- Webowe interfejsy administracyjne jak phpMyAdmin dla MySQL
- Narzędzia do wizualizacji danych z możliwością wykonywania zapytań SQL
- Platformy chmurowe oferujące interfejsy do zarządzania bazami danych
- Specjalistyczne narzędzia do monitorowania i optymalizacji wydajności baz danych

2. PODSTAWY: STRUKTURA BAZY I TYPY DANYCH2.1. Tabele, kolumny i wiersze

Tworzenie tabeli z określonymi kolumnami:

Aby utworzyć nową tabelę w bazie danych SQL, użyj polecenia CREATE TABLE. Składnia jest następująca:

CREATE TABLE nazwa_tabeli (

nazwa_kolumny1 typ_danych1 ,

nazwa_kolumny2 typ_danych2 ,

...

);

Przykład:

CREATE TABLE pracownicy (

id INT PRIMARY KEY,

imie VARCHAR(50) NOT NULL,

nazwisko VARCHAR(50) NOT NULL,

data_urodzenia DATE,

stanowisko VARCHAR(100),

pensja DECIMAL(10, 2)

);

W tym przykładzie:

- INT to typ całkowity dla identyfikatora
- VARCHAR to typ tekstowy o zmiennej długości
- DATE to typ daty
- DECIMAL to typ liczbowy z precyzją dziesiętną

Ograniczenia, takie jak PRIMARY KEY czy NOT NULL, definiują reguły dla danych w kolumnach.

Dodawanie wierszy do tabeli:

Aby dodać nowe wiersze do istniejącej tabeli, użyj polecenia INSERT INTO. Oto podstawowa składnia:

INSERT INTO nazwa_tabeli (kolumna1, kolumna2, ...)

VALUES (wartość1, wartość2, ...);

Przykład dodania pracownika do tabeli:

INSERT INTO pracownicy (id, imie, nazwisko, data_urodzenia, stanowisko, pensja)

VALUES (1, 'Jan', 'Kowalski', '1990-05-15', 'Programista', 5000.00);

Możesz też dodać wiele wierszy jednocześnie:

INSERT INTO pracownicy (id, imie, nazwisko, data_urodzenia, stanowisko, pensja)

VALUES

(2, 'Anna', 'Nowak', '1985-10-20', 'Manager', 7000.00),

(3, 'Piotr', 'Wiśniewski', '1992-03-08', 'Analityk', 4500.00);

Modyfikowanie istniejących kolumn w tabeli:

Do modyfikacji struktury istniejącej tabeli służy polecenie ALTER TABLE. Oto kilka przykładów:

Dodawanie nowej kolumny:

ALTER TABLE pracownicy

ADD COLUMN email VARCHAR(100);

Zmiana typu danych kolumny:

ALTER TABLE pracownicy

ALTER COLUMN pensja DECIMAL(12, 2);

Usuwanie kolumny:

ALTER TABLE pracownicy

DROP COLUMN stanowisko;

Zmiana nazwy kolumny (składnia może się różnić w zależności od systemu zarządzania bazą danych):

ALTER TABLE pracownicy

RENAME COLUMN imie TO pierwsze_imie;

Dodawanie ograniczenia:

ALTER TABLE pracownicy

ADD CONSTRAINT uq_email UNIQUE (email);

Nazywanie tabel i kolumn zgodnie z najlepszymi praktykami:

- Używaj rzeczowników w liczbie mnogiej dla nazw tabel: customers, orders, products.
- Stosuj konwencję snake\_case dla nazw tabel i kolumn: user\_accounts, first\_name.
- Unikaj słów kluczowych SQL jako nazw: zamiast "order" użyj "customer\_order".
- Bądź konsekwentny w nazewnictwie: jeśli używasz prefiksu "customer\_" w jednej tabeli, stosuj go we wszystkich powiązanych.
- Używaj pełnych, opisowych nazw: zamiast "addr", użyj "address".
- Unikaj skrótów, chyba że są powszechnie zrozumiałe: "id" jest akceptowalne, ale "qty" lepiej zapisać jako "quantity".
- Dla kolumn z kluczami obcymi, używaj nazwy tabeli w liczbie pojedynczej z sufiksem "\_id": user\_id w tabeli orders.

Określanie odpowiednich typów danych dla kolumn:

- Dla liczb całkowitych:
- TINYINT dla małych liczb (0 do 255)
- INT dla większości przypadków
- BIGINT dla bardzo dużych liczb
- Dla liczb zmiennoprzecinkowych:
- DECIMAL lub NUMERIC dla precyzyjnych obliczeń (np. kwoty pieniężne)
- FLOAT lub DOUBLE dla przybliżonych wartości naukowych
- Dla tekstu:
- CHAR(n) dla stałej długości tekstu
- VARCHAR(n) dla zmiennej długości tekstu
- TEXT dla długich fragmentów tekstu
- Dla dat i czasu:
- DATE dla samej daty
- TIME dla samego czasu
- DATETIME lub TIMESTAMP dla daty i czasu
- Dla wartości logicznych:
- BOOLEAN lub TINYINT(1)
- Dla danych binarnych:
- BLOB dla dużych obiektów binarnych
- Wybieraj najmniejszy możliwy typ danych, który pomieści wszystkie potencjalne wartości.

Usuwanie tabel i wierszy:

Usuwanie całej tabeli:

DROP TABLE nazwa_tabeli;

Przykład:

DROP TABLE pracownicy;

Usuwanie wszystkich wierszy z tabeli bez usuwania samej tabeli:

DELETE FROM nazwa_tabeli;

Przykład:

DELETE FROM pracownicy;

Usuwanie określonych wierszy z tabeli:

DELETE FROM nazwa_tabeli

WHERE warunek;

Przykład:

DELETE FROM pracownicy

WHERE data_urodzenia < '1980-01-01';

- Przed usunięciem danych zawsze twórz kopię zapasową.
- Używaj klauzuli WHERE ostrożnie, aby uniknąć przypadkowego usunięcia zbyt wielu danych.
- Rozważ użycie transakcji dla bezpieczniejszego usuwania:

BEGIN TRANSACTION;

DELETE FROM pracownicy WHERE id = 5;

-- Sprawdź, czy usunięto właściwe dane

COMMIT; -- lub ROLLBACK, jeśli coś poszło nie tak

- W przypadku dużych tabel, usuwanie partiami może być wydajniejsze:

DELETE TOP(1000) FROM duza_tabela

WHERE data < '2020-01-01';

Przeglądanie struktury istniejącej tabeli:
mniej..

BESTSELLERY

Kategorie: