![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 764 Pomógł: 3 Dołączył: 30.04.2003 Ostrzeżenie: (0%) ![]() ![]() |
Witam serdecznie,
zastanawia mnie jedna roznica pomiedzy tymi dwoma SZBD. Przykład: mam kod tworzacy tabele MySQL:
oraz PostgreSQL Cytat CREATE TABLE test ( id SERIAL NOT NULL, imie VARCHAR(40) NOT NULL UNIQUE, PRIMARY KEY (id) ); Następnie wykonuję następujące zapytania: MySQL:
PostgreSQL:
Następnie: i wyniki: MySQL: Kod +----+--------+ | id | imie | +----+--------+ | 1 | Michal | | 2 | Tomek | +----+--------+ 2 rows in set (0.01 sec) PostgreSQL: Kod template1=# SELECT * FROM test; 1 | Michal 3 | Tomek I moje pytanie jest następujące: dlaczego PostgreSQL w przypadku nieudanej proby dodania nowej pozycji (tutaj za sprawa UNIQUE) juz "rezewuje" klucz glowny o numerze 2 (w przeciwienstwie do MySQL'a). Wlasciwie przy tego typu opecji wszystko jedno jaka wartosc bedzie mial klucz glowny, pytam tylko z czystej ciekawosci. Mam tutaj swoja teorie dlaczego tak sie dzieje, natomiast nie chcialbym zmyslac dlatego tez pytam. Moze ktos z Was wie jak to wyglada w innych SZBD. Pozdrawiam. |
|
|
![]() ![]() |
![]() |
Aktualny czas: 30.09.2025 - 03:33 |