Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Bardzo wolny INSERT
Forum PHP.pl > Forum > Bazy danych > PostgreSQL
Cezar708
Czesc.

Uzywam PostgreSQL 8.1.3, do tego obsluguje to php 4.3.9.

W tranzakcji dodaje dane do 6 tabel, oczywiscie maja miedzy soba relacje.

Wszytko dzialalo niezle (szybko) do momentu.... w jednej z tabel pojawilo sie ponad 42 000 krotek (a krotki nie sa zbyt ciezkie). i wprowadzenie kolejnych przysparza wiele problemow.

Jesli (testowo) wyczyszcze wszystkie "zainteresowane" tabele, to tranzakcja trwa w mgnieniu oka, w zasadzie sprowadza sie tylko do przeladowania ekranu z napisem "wprowadzono dane". Niestety gdy mam te same tabele, tylko ze z wielka iloscia danych to inserty trwaja okolo 2-3min...

Zatem pytanie, co moze byc "waskim gardlem" i czy jest jakas mozliwosc optymalizacji INSERTow? Bede bardzo wdzieczny za wszelka pomoc
Jabol
Zajrzyj tutaj. Dokumentacja dotycząca poleceń EXPLAIN oraz ANALYZE. Może Ci pomogą.
DeyV
Piersze wrażenie -błędnie założone indexy.
SongoQ
Relacje i indeksy podczas INSERTow spowalniaja prace bazy bo to wszystko musi byc wewnetrznie sprawdzone i odbudowane.
DeyV
jeśli jednak pomiedzy tabelami są relacje, wtedy zależności muszą być sprawdzone podczas dodawania.

A jeśli brak indexu na sprawdzanych kolumnach - wtedy może to bardzo negatywnie wpływać na wydajność.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.