PostgreSQL (/poːstɡɹ ɛs kjuː ɛl/), także Postgres – obok MySQL i SQLite, jeden z najpopularniejszych otwartych systemów zarządzania relacyjnymi bazami danych. Początkowo opracowywany na Uniwersytecie Kalifornijskim w Berkeley i opublikowany pod nazwą Ingres. W miarę rozwoju i zwiększania funkcjonalności, baza danych otrzymała nazwy Postgres95 i ostatecznie PostgreSQL, aby upamiętnić pierwowzór oraz zaznaczyć zgodność ze standardem SQL. Aktualnie baza implementuje większość standardu SQL:2016.
Większość dystrybucji Linuksa zawiera pakiety umożliwiające instalację bazy PostgreSQL. MacOS, od wersji Lion, posiada pakiety instalacyjne bazy w wersji serwerowej systemu operacyjnego oraz narzędzia klienckie w wersji desktopowej.
PostgreSQL zalicza się do baz typu RDBMS z rozszerzeniami obiektowymi.
== Nazwa projektu ==
Użycie liter różnej wielkości w nazwie PostgreSQL prowadzi często do nieporozumień. Oficjalną i jedyną nazwą jest PostgreSQL. Często używanym zdrobnieniem jest Postgres. Nazwa nawiązuje do początków projektu jako „post-Ingres”.
== Platformy ==
=== Systemy operacyjne ===
PostgreSQL działa na następujących systemach operacyjnych: Linux (wszystkie niedawne dystrybucje), Windows (Win2000 SP4 i późniejszy), FreeBSD, OpenBSD, NetBSD, macOS, AIX, BSD/OS, HP-UX, IRIX, OpenIndiana, OpenSolaris, SCO OpenServer, SCO UnixWare, Solaris i Tru64 Unix.
W 2012 r. wsparcie dla następujących systemów zostało usunięte: DG/UX, NeXTSTEP, SunOS 4, SVR4, Ultrix 4 oraz Univel.
W większości pozostałych systemów Uniksowych i uniksopodobnych również powinna działać.
=== Architektury ===
PostgreSQL działa na architekturach sprzętowych takich jak: x86, x86-64, IA64 Itanium, PowerPC, PowerPC 64, S/390, S/390x, SPARC, SPARC 64, Alpha, ARM, MIPS, MIPSel, M68k, PA-RISC, M32R, NS32k i VAX. Dodatkowo można zbudować PostgreSQLa dla niewspieranych procesorów poprzez wyłączenie spinlocków.
== Cechy ==
=== Funkcje ===
W samej bazie można pisać procedury składowane w różnych językach programowania. Domyślnie dostępne są:
PL/pgSQL, podobny do proceduralnego języka PL/SQL w bazie Oracle;
PL/Python;
PL/Perl;
PL/Tcl;
język SQL (procedura to ciąg parametryzowanych instrukcji SQL).
Dodatkowo można zainstalować rozszerzenia udostępniające:
języki skryptowe: PL/Lua, plPHP, PL/Ruby, PL/sh, PL/Scheme, PL/LOLCODE;
języki kompilowane: C, C++ oraz Java (jako PL/Java);
język statystyczny R jako PL/R.
=== Indeksy ===
W PostgreSQL zaimplementowano obsługę wielu typów indeksów, do których należą:
B-drzewo,
Hash, używany tylko przy korzystaniu z operatora =,
GiST, obsługuje różne strategie indeksowania dla różnych danych np. zamiennik indeksu R-drzewo dla danych geometrycznych,
SP-GiST,
BRIN,
GIN, stosowany do indeksowania wielu danych przetrzymywanych w jednej kolumnie.
Indeksy można utworzyć zarówno na kolumnie, lub kolumnach tabeli, jak i widoku zmaterializowanego.
Indeksy posiadają dodatkowe możliwości:
Indeksy funkcyjne, gdzie indeks jest wynikiem funkcji, a nie wartości kolumny.
Indeksy częściowe, czyli indeksy reprezentujące część tabeli, mogą zostać utworzone przez dodanie klauzuli „WHERE” na końcu CREATE INDEX.
Ustawienie kolejności sortowania wartości w indeksie malejąco (DESC), lub rosnąco (ASC).
W razie potrzeby PostgreSQL może przeglądać indeksy od końca.
Określenie położenia wartości NULL – na początku (FIRST) lub końcu indeksu (LAST).
Współbieżne budowanie i usuwanie indeksu.
Od wersji 8.1 możliwe jest łączenie indeksów podczas wykonywania zapytania przy użyciu tzw. bitmap indeksowych.
Od wersji 9.2 możliwe są index-only scany, dzięki temu baza wykonując zapytanie może korzystać tylko z indeksu i z niego wyciągnąć wszystkie dane potrzebne do zwrócenia. Umożliwia to szybsze zapytania, bo nie trzeba przeszukiwać pliku z danymi, a pliki z indeksami są przeważnie znacznie mniejsze.
Istnieje też możliwość zaimplementowania własnego typu indeksu, który będzie używany przez bazę danych.
=== Wyzwalacze ===
Posiada mechanizm wyzwalaczy (ang. triggers). Wyzwalacze są uruchamiane automatycznie przed lub po operacjach takich jak UPDATE, INSERT, DELETE i TRUNCATE. Do widoków można użyć mechanizmu reguł (ang. rules) by w ten sposób symulować możliwość zmieniania danych w widoku, który w PostgreSQL-u jest z zasady tylko do odczytu. Od wersji 9.1 można także tworzyć wyzwalacze na widokach.
Od wersji 9.3 możliwe jest tworzenie tzw. event triggers, wyzwalaczy reagujących na instrukcje DDL, m.in. CREATE TABLE, CREATE INDEX, CREATE FUNCTION.
Wyzwalacz jest mechanizmem uruchamiającym procedurę, która może być napisana w dowolnym języku proceduralnym, który jest obsługiwany przez bazę, m.in. PL/SQL, PL/Perl, PL/Python lub PL/Tcl.
=== MVCC ===
PostgreSQL ma zaimplementowany mechanizm MVCC (Multiversion Concurrency Control) do zarządzania transakcjami. Mechanizm ten umożliwia udostępnienie tej samej krotki więcej niż jednej transakcji. Równocześnie może istnieć przynajmniej kilka wersji tej samej krotki, które nie są widoczne dla innych użytkowników do zakończenia danych transakcji. Dzięki temu baza danych wydajnie zachowuje zasadę ACID.
=== Reguły ===
Reguły są to elementy aktywne, które mogą być stosowane m.in. jako rozszerzenie widoków. Za pomocą reguł można zrealizować widoki modyfikujące, jako że reguły mogą mieć w definicji klauzulę INSTEAD OF co spowoduje, że robiąc zapytanie INSERT wstawiające dane do widoku, reguła zamiast tego zapytania zrobi inne, które wstawi dane do tabeli (bądź wielu tabel), z której widok odczytuje dane.
=== Typy danych ===
Rozszerzona jest definicja typów danych o nowe typy m.in.:
typ logiczny (boolean)
typy liczbowe
liczby całkowitych (smallint, integer, bigint)
liczby zmiennoprzecinkowych (real, double precision)
liczby niecałkowite o dokładnej reprezentacji (numeric, decimal)
typy tekstowe (text, character alias char, character varying alias varchar)
typy binarne (bit, bit varying)
typy do przechowywania daty i czasu (timestamp/time with/without timezone, date, interval)
typ do obliczeń walutowych (money) – typ ten nie jest zalecany do użytku
typ wyliczeniowy (enum)
typ złożony (rekordowy)
typ tablicowy
typy do wyszukiwania pełnotekstowego (tsvector, tsquery)
typy geometryczne (point, line, lseg, box, path, polygon, circle)
typy adresów sieciowych (cidr, inet, macaddr)
XML, obsługujący również wyrażenia XPath (od wersji 8.3)
UUID (od wersji 8.3)
JSON (od wersji 9.2)
typy zakresowe (Range Type) (od wersji 9.2)
Dodatkowo użytkownicy mogą definiować własne typy danych, które całkowicie korzystają z infrastruktury GIST PostgreSQL. Doskonałym przykładem jest zdefiniowanie typów danych geograficznych na potrzeby systemów informacji geograficznej (GIS) w module PostGIS.
=== Obiekty definiowane przez użytkownika ===
Można tworzyć większość obiektów bazodanowych m.in.:
rzutowania
konwersje typów
typy danych
domeny
funkcje, włączając w to funkcje agregujące
indeksy, włączając w to indeksy dla definiowanych typów danych
operatory, istniejące mogę być nadpisane
języki proceduralne
=== Ograniczenia wielkości elementów bazy ===
=== Inne cechy ===
Silnik ten zawiera wiele obiektowych rozszerzeń takich jak możliwość definiowania nowych typów podstawowych i dziedziczenia typów tablic.
Posiada zaawansowany system transakcji, dwufazowe zatwierdzanie (2PC) i możliwość dodawania funkcjonalności m.in. dzięki modułom zawartym w zbiorze „contrib”.
Jednym z pierwszorzędnych celów twórców PostgreSQL jest jak największa zgodność ze standardem SQL.
PostgreSQL jest dostępny na platformy: AIX, FreeBSD, HP-UX, IRIX, Linux, Mac OS, Microsoft Windows, NetBSD, OpenBSD, Solaris i UnixWare.
PostgreSQL jest dostępny na licencji Postgresql, podobnej do licencji BSD oraz licencji MIT
==== Narzędzia do współpracy z bazą danych ====
pgAdmin
phpPgAdmin – administracja za pomocą przeglądarki internetowej
psql
DBeaver
TOra
EMS SQL Manager for PostgreSQL Freeware
== Historia ==
Historia rozwoju PostgreSQL sięga 1973 roku. Wtedy to dr Michael Stonebraker wraz z Eugene Wong rozpoczęli badania nad relacyjnymi systemami baz danych. Efektem tych badań było rozpoczęcie projektu Ingres na Uniwersytecie Kalifornijskim w Berkeley, w 1977 roku. Projekt prowadzony był pod kierunkiem dr Michaela Stonebrakera, który w 1982 roku opuścił uczelnię, zakładając firmę, która zajęła się skomercjalizowanym systemem Ingres. Jednak wkrótce, w 1984 roku wrócił na uczelnię.
W 1985 roku rozpoczęto pod kierunkiem prof. Michaela Stonebrakera prace badawcze nad projektem obiektowo-relacyjnej bazy danych Postgres (post-ingres). Postgres został wyposażony w zaawansowany język zapytań POSTQUEL. Następnie w 1987 roku wprowadzono do Postgresa reguły, procedury, typy i elementy obiektowe. Projekt ten był sponsorowany przez Defense Advanced Research Projects Agency (DARPA), Army Research Office (ARO), National Science Foundation (NSF) i ESL, Inc. Również ten projekt został skomercjalizowany, nadano mu nazwę Illustra. Ostatecznie komercyjny już system Illustra wykupiła firma Informix. Firma Informix użyła system Illustra w swoim produkcie Universal Server. W przeciwieństwie do projektu Ingres, projekt Postgres był nadal udoskonalany na uniwersytecie. Wersję oznaczoną numerem 1 opublikowano w czerwcu 1989 roku. Następnie w 1990 roku została opublikowana wersja 2, w której przepisano system reguł. Natomiast w 1991 roku ukazała się wersja 3 zawierająca m.in. przepisany na nowo systemem reguł i poprawiony silnik zapytań. Ostatnią wersją projektu Postgres była wersja 4.2, która nadal bazowała na języku zapytań POSTQUEL.
Dwaj absolwenci, członkowie zespołu Stonebrakera, Andrew Yu i Jolly Chen w 1994 roku dodali interpreter języka SQL, zastępując język zapytań POSTQUEL. Projekt ten udostępniono na licencji BSD w maju 1995 roku jako Postgres95. Dalszą pracą nad projektem podjęła w 1996 roku społeczność Open Source, zmieniając nazwę projektu na PostgreSQL i tworząc organizację PostgreSQL Global Development Group do koordynacji rozwoju projektu. Zdecydowano się, że nowa wersja będzie oz
>_ Administrator Baz Danych Oracle
profession // Entity_Profile
[DATA] PostgreSQL (/poːstɡɹ ɛs kjuː ɛl/), także Postgres – obok MySQL i SQLite, jeden z najpopularniejszych otwartych systemów zarządzania relacyjnymi bazami danych. Początkowo opracowywany na Uniwersytecie Kalifornijskim w Berkeley i opublikowany pod nazwą Ingres. W miarę rozwoju i zwiększania funkcjonalności, baza danych otrzymała nazwy Postgres95 i ostatecznie PostgreSQL, aby upamiętnić pierwowzór ora
[METRICS] Encja posiada 0 wzmianek w bazie oraz 0 powiązanych artykułów. Trust Score: 50/100.
Wersja statyczna dla wyszukiwarek. Pełna wersja interaktywna z grafiką dostępna po włączeniu JavaScript.