Skocz do zawartości
Zamknięcie Forum PC LAB

Szanowny Użytkowniku,

Informujemy, że za 30 dni tj. 30 listopada 2024 r. serwis internetowy Forum PC LAB zostanie zamknięty.

Administrator Serwisu Forum PC LAB - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie: wypowiada całość usług Serwisu Forum PC LAB z zachowaniem miesięcznego okresu wypowiedzenia.

Administrator Serwisu Forum PC LAB informuje, że:

  1. Z dniem 29 listopada 2024 r. zakończy się świadczenie wszystkich usług Serwisu Forum PC LAB. Ważną przyczyną uzasadniającą wypowiedzenie jest zamknięcie Serwisu Forum PC LAB
  2. Dotychczas zamowione przez Użytkownika usługi Serwisu Forum PC LAB będą świadczone w okresie wypowiedzenia tj. do dnia 29 listopada 2024 r.
  3. Po ogłoszeniu zamknięcia Serwisu Forum od dnia 30 października 2024 r. zakładanie nowych kont w serwisie Forum PC LAB nie będzie możliwe
  4. Wraz z zamknięciem Serwisu Forum PC LAB, tj. dnia 29 listopada 2024 r. nie będzie już dostępny katalog treści Forum PC LAB. Do tego czasu Użytkownicy Forum PC LAB mają dostęp do swoich treści w zakładce "Profil", gdzie mają możliwość ich skopiowania lub archiwizowania w formie screenshotów.
  5. Administrator danych osobowych Użytkowników - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie zapewnia realizację praw podmiotów danych osobowych przez cały okres świadczenia usług Serwisu Forum PC LAB. Szczegółowe informacje znajdziesz w Polityce Prywatności

Administrator informuje, iż wraz z zamknięciem Serwisu Forum PC LAB, dane osobowe Użytkowników Serwisu Forum PC LAB zostaną trwale usunięte ze względu na brak podstawy ich dalszego przetwarzania. Proces trwałego usuwania danych z kopii zapasowych może przekroczyć termin zamknięcia Forum PC LAB o kilka miesięcy. Wyjątek może stanowić przetwarzanie danych użytkownika do czasu zakończenia toczących się postepowań.

Temat został przeniesiony do archiwum

Ten temat przebywa obecnie w archiwum. Dodawanie nowych odpowiedzi zostało zablokowane.

voidsn1010

Optymalizacja zapytań MySQL

Rekomendowane odpowiedzi

Witam,

 

widziałem kiedyś na jakimś silniku forum czy CMS'a w stopce przykładową informację: '8 queries to database'.

 

Od tego czasu często zastanawia mnie, jak duży wpływ ma ilość zapytań do bazy na działanie powiedzmy średniego portalu.

 

Często w swoich silnikach wykonuję około 50 zapytań albo i więcej. Przykładowo strona wczytuje kilka postów i do każdego posta wczytuje z bazy ilość komentarzy (zlicza), oprócz tego jest kilka zapytań, które wymaga silnik.

 

Czy powinienem przykładać dużą wagę do minimalizacji ilości zapytań, czy może większe znaczenie ma ilość danych zwracanych przez zapytanie?

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Czy powinienem przykładać dużą wagę do minimalizacji ilości zapytań, czy może większe znaczenie ma ilość danych zwracanych przez zapytanie?

 

i to i to

 

masz zaimplementowany jakiś mechanizm cachowania gotowych stron (w sensie stronę regenerujesz tylko jak zmieniło się coś w bazie)?

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Korzystam z frameworka, który prawdopodobnie pozwala wykonywać cache, jednak w tej chwili z tego nie korzystam.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Zapytanie zapytaniu nierówne, można zrobić 10 zapytań osobno albo jedno duże.

Poza tym zainteresuj się indeksami, potrafią sporo dać przy dużej ilości rekordów i odpowiedniej strukturze bazy.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Rzeczy wpływających na wydajność bazy danych jest sporo, np:

  • indeksy
  • partycjonowanie tabel
  • rozmiar puli połączeń
  • podzapytania skorelowane

A jeżeli używasz jakiegoś frameworka, który pod spodem ma ORM, mogą pojawić się problemy z n+1 zapytań czy eager loading.

 

Ja bym zaczął od małej puli połączeń, sensownych indeksów i joina w SQLu.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

1. zliczanie rekordów raz za razem jest złym pomysłem

2. mała liczba zapytań, ale nie na siłę, szczególnie gdy jedno większe zarzyna bazę, a dwa mniejsze działają płynnie

3. * w select tylko jeśli pokazujesz wszystkie dane, w przeciwnym wypadku tylko to, co jest używane w danym momencie

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

  • Ostatnio przeglądający   0 użytkowników

    Brak zarejestrowanych użytkowników przeglądających tę stronę.

×
×
  • Dodaj nową pozycję...