Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [php][mysqli] multi_query i query
Forum PHP.pl > Forum > PHP
therias
Witam.
Mam problem, gdy mój skrypt wygląda tak:
  1. <?php
  2. //..pomijam polaczenie z baza itd...
  3. $db->multi_query("INSERT........; INSERT............; UPDATE...............;"); //przykladowe zapytanie
  4. //.....
  5. $db->query("SELECT........."); //wybranie rekordow
  6. ?>

w moim przypadku przykladowe zapytanie to dodanie firmy do katalogu, powiazanie z kategoriami, +1 do ilosci firm w katalogu. Później wybieram rekordy by zobaczyc zmiany.... i tu pojawia sie błąd:

Fatal error: Call to a member function fetch_assoc() on a non-object in /home/kontko/ftp/test/test.php on line 23

Czym to może być spowodowane? Może trzeba jakoś "zresetować" result z poprzedniego zapytania?
Help! smile.gif
Pozdrawiam
kosmos
Za mało pokazałeś smile.gif

Wklej normalnie kod i pokaż linijke 23
therias
Za duzo by wklejać tongue.gif generalnie to wyglada tak: Mam klase Firma, gdzie mam statyczna metode
  1. <?php
  2. static public function addFirma($dane, $foto_title, $logo) {
  3. global $db;
  4.  
  5. $query = "INSERT INTO ".TAB_KF_FIR." VALUES (null, '".$dane['nazwa']."', '".$dane['miasto']."', '".$dane['kodp']."', '".$dane['adres']."', '".$dane['tel_dom']."', '".$dane['tel_kom']."', '".$dane['tel_fax']."', '".$dane['slowa_klucz']."', '".$dane['email']."', '".$dane['www']."', '".nl2br($dane['opis'])."', '".$dane['osoba']."');
  6. INSERT INTO ".TAB_KF_CZE." VALUES (LAST_INSERT_ID());";
  7.  
  8. if(!empty($dane['idKat1']) || !empty($dane['idKat2']) || !empty($dane['idKat3'])) {
  9. $query .= "INSERT INTO ".TAB_KF_KAFI." VALUES "
  10. .($dane['idKat1']?"(LAST_INSERT_ID(), ".$dane['idKat1']."),":'')
  11. .($dane['idKat2']?"(LAST_INSERT_ID(), ".$dane['idKat2']."),":'')
  12. .($dane['idKat3']?"(LAST_INSERT_ID(), ".$dane['idKat3']."),":'');
  13. $query = substr($query, 0, strlen($query)-1).";";
  14. }
  15.  
  16. if(!empty($logo)) {
  17. rename('photos/kf/temp_'.$logo.'_m.jpg', 'photos/kf/'.$foto_title.'_'.$logo.'_m.jpg');
  18. $query .= "INSERT INTO ".TAB_KF_LOGO." VALUES (LAST_INSERT_ID(), '".$foto_title."_".$_SESSION['logo']."');";
  19. }
  20.  
  21. if($db->multi_query($query)) {
  22. return true;
  23. } else {
  24. return false;
  25. }
  26. }
  27. ?>

Po dodaniu ma sie pokazac komunikat i tabela z firmami:
  1. <?php
  2. $res = $db->query("SELECT * FROM ".TAB_KF_FIR.";");
  3. $rek = $res->fetch_assoc(); //to jest linijka 23 :)
  4. //......
  5. ?>
tomeksobczak
Cytat(therias @ 18.06.2008, 20:17:46 ) *
Za duzo by wklejać tongue.gif generalnie to wyglada tak: Mam klase Firma, gdzie mam statyczna metode

Właśnie wkleiłeś 27 linii kodu, a 23 to za dużo?
therias
miałem na myśli gdybym miał wklejać cały kod skryptu smile.gif
kosmos
Na początek wywal ten global ... zastąp sesją
W OOP broń się od global smile.gif
therias
sesją? :| Jak mam to niby zrobić?
nospor
Cytat
Na początek wywal ten global ... zastąp sesją

Cytat
sesją? :| Jak mam to niby zrobić?

Kolega chyba sie przejęzyczył z tą sesją winksmiley.jpg

Co do problemu:
  1. <?php
  2. $res = $db->query("SELECT * FROM ".TAB_KF_FIR.";");
  3. ?>

Zwraca ci false, znaczy masz blad zapytania. wyswietl sobie blad i zobacz co masz źle
  1. <?php
  2. $res = $db->query("SELECT * FROM ".TAB_KF_FIR.";");
  3. echo $db->error;
  4. ?>
therias
"Commands out of sync; you can't run this command now" :/
kosmos
Cytat(nospor @ 18.06.2008, 22:33:14 ) *
Kolega chyba sie przejęzyczył z tą sesją winksmiley.jpg


Lubie sesje biggrin.gif

Serio sory za to ;]
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.