Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Klasa bazy danych, Problem z klasą do obsługi bazy danych
Diwi
post
Post #1





Grupa: Zarejestrowani
Postów: 245
Pomógł: 4
Dołączył: 22.01.2005

Ostrzeżenie: (0%)
-----


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
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 20.08.2025 - 12:05