Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> PDO
jeremiash
post
Post #1





Grupa: Zarejestrowani
Postów: 94
Pomógł: 5
Dołączył: 6.11.2012

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


Cześć. Wiem, że jest wiele podobnych wątków, z których z resztą osobiście korzystałem, ale mimo to napotkałem problem ... a pomysłów mi brakło. Postanowiłem iść z duchem rozwoju i przerzucając się na OOP napotkałem taki oto problem. Dla mnie bariera, a dla Was pewno odpowiedź banalna jak splunięcie. Proszę zatem o pomoc.

Utworzyłem klasę do łączenia się z bazą danych, i teraz chcę to połączenie wykorzystywać na stronie... jak to ktoś tutaj ładnie określił, metodą 'wstrzykiwania' obiektu z połączeniem do obiektów innych klas. Niestety wyrzuca mi błąd przy funkcji query() : " Call to undefined method PodlaczenieBazyDanych::query()..." pomocy.

  1. class PodlaczenieBazyDanych {
  2.  
  3. public function __construct()
  4.  
  5. {
  6.  
  7. try{
  8. $pdo = new PDO('mysql:host=localhost;dbname=aaa', 'root', 'root', array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));
  9. $pdo -> setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  10. }
  11. catch(PDOException $e)
  12. {
  13. echo 'blad przy polaczeniu z db: ' . $e->getMessage();
  14. }
  15.  
  16. }
  17.  
  18. }
  19.  
  20. class query
  21. {
  22. private $polaczenie;
  23.  
  24. public function lista($polaczenie) {
  25.  
  26. try
  27. {
  28. $this->polaczenie=$polaczenie;
  29. $stmt = $this->polaczenie -> query('SELECT * FROM users');
  30. echo '<ul>';
  31. foreach($stmt as $row)
  32. {
  33. echo '<li>'.$row['pole1'].': '.$row['pole2'].': '.$row['pole3'].'</li>';
  34. }
  35. $stmt -> closeCursor();
  36. echo '</ul>';
  37. }
  38. catch(PDOException $e)
  39. {
  40. echo 'Połączenie nie mogło zostać utworzone: ' . $e->getMessage();
  41. }
  42.  
  43. }
  44.  
  45. }
  46.  
  47. $a=new PodlaczenieBazyDanych;
  48. $aa= new query;
  49. $aa->lista($a);
Go to the top of the page
+Quote Post
skowron-line
post
Post #2





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

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


Jeżeli chcesz tak zrobić to w konstruktorze musisz zwrócić obiekt PDO, ale że tak się nie da to zmień to na
  1. class PodlaczenieBazyDanych {
  2.  
  3. public function connect()
  4.  
  5. {
  6.  
  7. try{
  8. $pdo = new PDO('mysql:host=localhost;dbname=aaa', 'root', 'root', array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));
  9. $pdo -> setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  10.  
  11. return $pdo;
  12. }
  13. catch(PDOException $e)
  14. {
  15. echo 'blad przy polaczeniu z db: ' . $e->getMessage();
  16. }
  17.  
  18. }
  19.  
  20. }


i
  1. $a=new PodlaczenieBazyDanych;
  2. $aa= new query;
  3. $aa->lista($a->connect());


--------------------
I'm so fast that last night I turned off the light switch in my hotel room and was in bed before the room was dark - Muhammad Ali.
Peg jeżeli chcesz uprawiać sex to dzieci muszą wyjść, a jeżeli chcesz żeby był dobry ty też musisz wyjść - Al Bundy.

QueryBuilder, Mootools.net, bbcradio1::MistaJam
http://www.phpbench.com/
Go to the top of the page
+Quote Post
jeremiash
post
Post #3





Grupa: Zarejestrowani
Postów: 94
Pomógł: 5
Dołączył: 6.11.2012

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


wielkie dzięki, ruszyło smile.gif
Go to the top of the page
+Quote Post

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: 22.08.2025 - 01:16