Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: problem z polaczeniem z baza
Forum PHP.pl > Forum > PHP > Object-oriented programming
Czarnulson
Witam, mam pewien problem.

mam klase polaczenia z baza sql.class.php, ktora inluduje w pliku glownym. Tworze obiekt:

  1. <?php
  2. $sql = new Sql;
  3. $sql -> connect(tu dane serwera itp);
  4. ?>


i tu wszystko dziala poprawnie. Includuje plik user.class.php w ktorym mam metode w ktorej chce pobrac dane z bazy:

  1. <?php
  2. $ask = "SELECT id FROM user WHERE login = '$login'";
  3. $result = $sql->query($ask);
  4. $numRows = $sql->numRows($result);
  5. ?>


i tu pojawia sie blad: Fatal error: Call to a member function query() on a non-object in...

Czy ktos wie co to moze oznaczac?

pozdrawiam
nevt
zakładam że user.class.php to definicja klasy user, zatem fragment:
  1. <?php
  2. $ask = "SELECT id FROM user WHERE login = '$login'";
  3. $result = $sql->query($ask);
  4. $numRows = $sql->numRows($result);
  5. ?>

znajduje się wewnątrz konstruktora klasy (lub innej metody). no i nie widzi twojej zmiennej globalnej $sql;
masz dwa wyjścia:
1. odwołać się do zmiennej globalnej (niezalecane), wystarczy że dopiszesz przed swoim kodem linijkę:
  1. <?php
  2. global $sql;
  3. ?>

2. przekazać jawnie (zalecane) do konstruktora lub metody obiekt $sql:
  1. <?php
  2. // w klasie user
  3. public metoda($baza)
  4. {
  5. $ask = "SELECT id FROM user WHERE login = '$login'";
  6.  $result = $baza->query($ask);
  7.  $numRows = $baza->numRows($result);
  8.  }
  9. //i wywołanie w pliku głównym
  10. user->metoda($sql);
  11. ?>

powodzenia.
.radex
Niepotrzebne utrudnienie moim zdaniem. Lepiej byłoby użyć np. Singletona, ale może wiesz lepiej winksmiley.jpg
nevt
jawne przekazywanie obiektu bazy ma znaczacą przewagę na odwoływaniem się do globali czy używaniem singletonów (co w sumie dla mnie jest tym samym)

umożliwia bowiem swobodne łączenie do różnych baz danych z różnych instancji tej samej klasy, umożliwia też tworzenie kilku równoległych połączeń do tej samej bazy (np. z innymi uprawnieniami).

a zmiana wywołania
  1. <?php
  2. $db = new mysql.class(...);
  3. $user = new user.class(...);
  4. // na
  5. $db = new mysql.class(...);
  6.  $user = new user.class($db, ...);
  7. ?>

chyba nie jest jakimś niebotycznym skomplikowaniem programu... jak dla mnie wręcz przeciwnie, bo od razu widzę na jakim zbiorze danych operuje klasa user bez konieczności zaglądania do jej kodu...

pozdrawiam wszystkich.
Czarnulson
dziekuje bardzo! smile.gif

pozdrawiam
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.