Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL][PHP]Zamykanie i otwieranie połączenia z bazą
Forum PHP.pl > Forum > Przedszkole
Wojciechovsky
Witam, mam na swojej stronie strukturę w postaci:

Otwórz połączenie z bazą - Sprawdź coś - zamknij połączenie - wypełnij formularz - otwórz połączenie z bazą - dodaj coś - zamknij połączenie z bazą.

Czy jest to poprawne? Czy w jednym pliku powinno się otworzyć bazę tylko raz, na początku i zamknąć ją na końcu?
kpt_lucek
PHP I tak zamyka połączenie z bazą po wykonaniu skryptu (a bynajmniej tak mnie uczono), więc możesz ale nie musisz go zamykać.
Fred1485
Ja też czytając o różnych metodach łączenia z bazą wszędzie byłem informowany że nie trzeba zamykać bo i tak php "zamknie" ale po każdym zapytaniu wypadało by zwolnić zestaw wyników (tak bynajmniej ja z tego wnioskowałem i tak robię) jeśli źle mówię to niech mnie ktoś poprawi biggrin.gif
Wojciechovsky
Dzięki za odpowiedź. Uczę się z tutoriali na youtubie i tam właśnie w każdym pliku za każdym razem jest zamykane połączenie.
Skoro mowa o "zwolnieniu zestawu wyników" to chodzi tutaj o metodę close albo free?
Pyton_000
Tak się nie robi. Tracisz wtedy czas na ponowne łączenie.
Jak już chcesz zwalniać zasoby to czymś pokroju: http://php.net/manual/pl/mysqli-result.free.php
viking
Przykładowe dane z profilera (baza postgres):

Kod
2.28ms     connect
1.16ms     SELECT...
0.73ms     SELECT ...
1.09ms     DELETE ...
1.13ms     SELECT ...

Jak widać connect ma najdłuższy czas. Jeśli zawsze zamykasz połączenie i robisz je od nowa, robisz to źle.
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.