Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!
Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.
Witam jaką baze byście polecali z darmowych rozwiązań?
Chciałbym tam zacząć składować spore ilości danych, ale nie wiem co wybrać:
- db2 express (biore ją pod uwagę bo w przyszłości planujemy zakup pełnej wersji, ale jest to jescze odległa przyszłość),
- mysql,
- postgres
???
Offline
Zależy co chcesz trzymać i z czego korzystać.
MySQL - bardzo szybki (jak dobrze pozakładane indeksy ale żeby działały trigery, transakcje trzeba użyć InnoDB a tu jest wolniejszy niż MYISAM), większość aplikacji webowych działa na nim.
PostgeSQL - chyba lepszy od MySQL choć często niedoceniany, trigery, transakcje itp. ma standardowo.
DB2 - nie wiem za wiele więc nie powiem.
Wiele też zależy od typu danych i relacji jakie masz zamiar trzymać w bazie. Więc tak ogólnie ciężko powiedzieć.
Offline
Miałem do czynienia tylko z MySQL i PostgreSQL. Jeżeli masz zamiar mieć kilka prostych, ale za to dużych tabel bez wymyślnych rzeczy to MySQL będzie najlepszy, natomiast jeżeli baza jest trochę bardziej skomplikowana (procedury składowane, selecty będą z dużą liczbą złączeń) to zdecydowanie lepszy będzie PostgreSQL.
Offline
Ja polecam PostgreSQL:
- z racji licencji
- niezawodności (w sensie: szybciej psułem bazę MySQL, bazy PostreSQL nie zdarzyło się by moje eksperymenty coś zniszczyły)
- bardziej przejrzysta struktura projektu (kilka plików i wiadomo co robią, wiadomo gdzie te pliki są, w MySQL jest bałagan) [w skrajnym przypadku: MySQL zajmuje 177 MiB, zaś PostgreSQL tylko 35 MiB]; prostota konfiguracji - w PostgreSQL to i ja odpalam wiele baz na raz, jakieś synchronizacje pomiędzy bazami robię bez pomocy ("plików pomocy") nawet
- może się okazać że projekt MySQL wkrótce zemrze... PostgreSQL powoli acz stale będzie się rozwijać
- PostgreSQL daje wszystko w standardzie (i pomocną pakę "contrib") - w MySQL trzeba kombinować (nawet nie wiem czy w PostgreSQL można zmieniać silniki tabel... nie było to potrzebne)
Offline
W zależności na jakiej bazie chodzi poszczególny skrypt php ...
Offline
zyga wszystko zależy do czego będziesz używał tych baz danych i w jakim charakterze
- czy ma to być jakaś aplikacja do której nie jest wymagany jednorazowy dostęp z dużej ilości stacji
- jak bardzo skomplikowana struktura tabel relacji i innych wynalazków
- co ma się komunikować z tą baza danych
- wielkość docelowa bazy w GB
- jaka będzie złożoność zapytań
Offline
Time (s) | Query |
---|---|
0.00011 | SET CHARSET latin2 |
0.00004 | SET NAMES latin2 |
0.00097 | SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='3.135.184.136' WHERE u.id=1 |
0.00072 | REPLACE INTO punbb_online (user_id, ident, logged) VALUES(1, '3.135.184.136', 1732374493) |
0.00043 | SELECT * FROM punbb_online WHERE logged<1732374193 |
0.00065 | DELETE FROM punbb_online WHERE ident='18.225.56.78' |
0.00059 | DELETE FROM punbb_online WHERE ident='216.244.66.250' |
0.00019 | SELECT topic_id FROM punbb_posts WHERE id=159620 |
0.00021 | SELECT id FROM punbb_posts WHERE topic_id=17842 ORDER BY posted |
0.00056 | SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=17842 AND t.moved_to IS NULL |
0.00004 | SELECT search_for, replace_with FROM punbb_censoring |
0.00127 | SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=17842 ORDER BY p.id LIMIT 0,25 |
0.00069 | UPDATE punbb_topics SET num_views=num_views+1 WHERE id=17842 |
Total query time: 0.00647 s |