Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Klasa bazy danych
Forum PHP.pl > Forum > PHP
Diwi
A więc mam sobie taką oto klasę do obsługi bazy danych:

  1. <?php
  2.  
  3. class db {
  4.  
  5. var $connect, $sd;
  6.  
  7.  
  8. function db() {
  9.  
  10. $this->connect = mysql_connect('localhost', 'root', 'gameforce') OR DIE (&#092;"Nie mogłem połączyć się z MySQL-em\");
  11. $this->sd = mysql_select_db('**') OR DIE ('Nie mogłem połączyć się z bazą danych: **');
  12.  
  13.  }
  14.  
  15. function query($z) {
  16.  
  17. @mysql_query(&#092;"$z\", $this->connect) OR DIE ('Błąd zapytania SQL: <br /><b>'.mysql_errno().' : '.mysql_error().'</b>');
  18.  
  19. } // function pytanie
  20.  
  21. function num_rows($query) {
  22.  
  23. @mysql_num_rows($query) OR DIE ('Błąd bazy danych: '.mysql_error());
  24.  
  25.  }
  26.  
  27. function fetch($pytanie) {
  28.  
  29. @mysql_fetch_assoc($pytanie, $this->connect) OR DIE ('Błąd bazy danych: '.mysql_error());
  30.  
  31.  }
  32.  
  33.  } // koniec klasy
  34.  
  35. ?>


Chyba wiadomo jak to działa: mamy konstruktor który przy wywołaniu odrazu otwiera połączenie z bazą danych + pare funkcji

Teraz mam klase do obsługi newsów "news" i chce wyświetlić newsy.

  1. <?php
  2.  
  3. if (eregi('news.php', $_SERVER['PHP_SELF'])) {
  4. exit('Hacking Attempt !!');
  5.  }
  6.  
  7. include_once('./config/db.lib.php');
  8. include_once('./templates/smarty.class.php');
  9. class news {
  10.  
  11. var $db, $tpl;
  12. function news() {
  13.  
  14. $this->db = new db;
  15. $this->tpl = new smarty;
  16. $this->tpl->template_dir = 'templates/tpl';
  17. $this->tpl->compile_dir = 'templates/tpl_c';
  18.  
  19.  }
  20.  
  21. function wyswietl_newsy() {
  22.  
  23. $result = $this->db->query(&#092;"SELECT * FROM `news` ORDER BY `add_date` DESC\");
  24.  
  25. while($row = $this->db->fetch($result)) {
  26.  // tutaj sobie robimy różne rzeczy na SMARTY
  27. }
  28.  
  29. }
  30. }
  31.  
  32. $news = new news;
  33. $news->wyswietl_newsy();
  34. ?>


Wydaje mi się że wszystko jest dobrze smile.gif. Lecz dostaje komunikat:

Kod
Błąd bazy danych:


Jak widać w klasie DB jest ustawione raportowanie błędów lecz po "Błąd bazy danych:" powinien się wyświetlić komunikat

Po usunięciu warunku OR DIE a także znaku @ przed funkcją dostaje taki komunikat:

Kod
Warning: mysql_fetch_assoc(): supplied argument is not a valid MySQL result resource in C:\WebServ\httpd\aa\config\db.lib.php on line 31


Zaznaczam że zapytanie SQL które wykonuje jest poprawne smile.gif

Co tu się dzieje questionmark.gif

Pozdrawiam
nospor
funkcja query() nie zwraca ci nic. a ty mimo wszystko z niej cos pobierasz, a potem to cos (czyli nic), przekazuje do fetch. A w fetch masz mysql_fetch_assoc, której argumentem nie może być nic. Kapisz?

Funkcja query powinna zwracac wynik funkcji mysql_query
SHiP
Ja bym to zrobił tak

  1. <?php
  2.  
  3.   function sql_query($query) 
  4.   { 
  5.     if(!$this -> result = @mysql_query($query)) $this -> errors[]=&#092;"Błędne zapytanie\";
  6.   }
  7.  
  8. ?>


I wtedy funkcje do wyciągania danych z bazy..

  1. <?php
  2.  
  3.   function sql_fetch_array($method) 
  4.   { 
  5.    if($method>|| $method<1) return 0; 
  6.     /*
  7.     1=ASSOC 
  8.     2=NUM 
  9.     3=BOTH (ASSOC + NUM) 
  10.     */ 
  11.     return @mysql_fetch_array($this -> result,$method);
  12.   }
  13.  
  14. ?>
Diwi
Acha czyli musze dać return ?

Myśle o czymś takim:

  1. <?php
  2.  
  3. // ...
  4. function query($z) {
  5.  
  6. return @mysql_query(&#092;"$z\", $this->connect) OR DIE ('Błąd zapytania SQL: <br /><b>'.mysql_errno().' : '.mysql_error().'</b>');
  7.  
  8. } // function query
  9.  
  10. // ...
  11. ?>


Coś takiego powinno działać questionmark.gif

Pozdrawiam
SHiP
Musisz po prostu rezultat funkcji mysql_query przypisać do jakiejść zmiennej - u mnie $this -> result

Tylko wtedy wyświetlanie będzie lekko inne
  1. <?
  2. $db -> sql_query(&#092;"SELECT * FROM `news` ORDER BY `add_date` DESC\");
  3. while($row = $db -> sql_fetch_array(1))
  4. {
  5. coś tam
  6. }
  7. ?>


Poza tym nie ruzumiem poco tworzyć obiekt jako zmienną klasy. Ja bym obiekt $db stworzył poza klasą news. I udostępnił go globalnie w wybranych funkcjach.
dasko
@SHiP: Głupi jest pomysł z przetrzymywaniem wyniku zapytania w $this->result. Takie rozwiązanie pozwala na istnienie tylko jednego wyniku w jednym czasie.

Wg mnie, najlepiej jest stworzyć klasę Result, która będzie zawierała wynik zapytania i metody operujące na wyniku SQL(fetchArray(), fetchObject, numRows() itd.) i właśnie instancję takiej klasy zwracać z metody db::sql_query() smile.gif
Ociu
Ja to zrobiłem tak:
  1. <?php
  2. # var $sql_result; etc.
  3. function query($sql)
  4. {
  5. $this -> sql_result = '';
  6.  
  7. $start = $this -> _get_time();
  8. if ($this -> connected && $this -> selected) # sprawdza czy jest polaczenie
  9. {
  10.  
  11. $this -> sql_result = mysql_query($sql, $this -> connected);
  12.  
  13. if(!$this -> sql_result)
  14. {
  15. $this -> err('query');
  16. return false;
  17. } else {
  18. $this -> execute++; #liczy zapytania
  19. return true;
  20. }
  21. } else {
  22. $this -> err('notconnect');
  23. }
  24. }
  25. ?>


fetch_row:
  1. <?php
  2. function fetch_row($fetch_row = '')
  3. {
  4. $fetch_row = ((empty($fetch_row)) ? $this -> sql_result : $fetch_row);
  5.  
  6. $r = mysql_fetch_array($fetch_row);
  7.  
  8. if($r)
  9. {
  10. return $r;  
  11. } else {
  12.  return false;
  13.  
  14. }
  15. }
  16. ?>
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.