Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [php][mysql] Wyciąganie danych do petli
Forum PHP.pl > Forum > Przedszkole
bemol
  1. <?php
  2. 7. $query = "SELECT * FROM users";
  3. 8. while ($row = mysql_fetch_array($query))
  4. 9. {
  5. 10. $pass_db[] = $row['pass'];
  6. 11.$login_db[] = $row['login'];
  7. 12. }
  8. ?>


Kod
Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in /home/poligrafia1/ftp/helmut/plaza/admin/login.php on line 8


Co jest źle? Czy rzeczywiście chodzi tutaj o 8 linijke? :/
Proszę o pomoc
cornholio666
brakuje ci mysql_query()
Sadu2
A tak będzie działać?

  1. <?php
  2. $query = mysql_query("SELECT * FROM users");
  3. while ($row = mysql_fetch_array($query))
  4. {
  5. $pass_db[] = $row['pass'];
  6. $login_db[] = $row['login'];
  7. }
  8. ?>
bemol
wielkie dzięki, wszystko już ok. no prawie...
mam pytanie, jak zrobić tak, by po skasowaniu rekordu z bazy danych, id tez się resetowalo?
moze przedstawie to obrazowo.
W bazie mam 5 rekordow

id "login" 'haslo'
1 "ja" 'zenek2'
2 "ty" 'zenek3'
3 "on" 'zenek7'
4 "ona" 'zenek1'
5 "ono" 'zenek0'

Przypuśćmy usuwam wszystkie rekordy. Dodaje nowy i będzie on wyglądał tak:

6 "my" 'zenek6'

A jak zrobić by wyglądał tak:

1 "my" 'zenek6'

?
Będe bardzo wdzięczny za podpowiedź.
phpion
Jeśli chcesz wyczyścić tabelę czyli usunąć wszystkie rekordy i wyzerować ew. auto_increment to zamiast:
  1. DELETE FROM tabela;

użyj:
  1. TRUNCATE TABLE tabela;

Działa szybciej niż DELETE bo nie usuwa rekordu po rekordzie tylko usuwa całą tabelę oraz odbudowuje jej strukturę w wyniku czego uzyskujesz nową, czystą tabelę.
bemol
to była tylko teoria, bo same rekordy usuwam z poziomu phpMyAdmin'a.
nie ma innego sposobu, by kolejne rekordy dodawało na najniższy możliwy id?
bo poki co dodaje sobie rekordy zeby sprawdzic czy działa i nie chce żeby pozniej gdy beda juz wyswietlane na stronce było: Numer newsa: 17 (np)
webdice
Cytat(bemol @ 22.12.2007, 18:38:25 ) *
to była tylko teoria, bo same rekordy usuwam z poziomu phpMyAdmin'a.
nie ma innego sposobu, by kolejne rekordy dodawało na najniższy możliwy id?
bo poki co dodaje sobie rekordy zeby sprawdzic czy działa i nie chce żeby pozniej gdy beda juz wyswietlane na stronce było: Numer newsa: 17 (np)


Przy polu AUTO_INCREMENT nie, chyba że ID będziesz podawał sam, a nie poprzez nadanie wartości NULL.
bemol
ok, wyłączyłem auto_increment i rozwiązałem to tak:

  1. <?php
  2. $query = mysql_query ("SELECT id FROM news");
  3. $numery = mysql_num_rows($query);
  4. $numer = $numery +1;
  5. ?>


  1. <?php
  2. $news = "INSERT INTO news (id, data, autor, tresc) VALUES ('$numer' , now(), '$autor', '$tresc')";
  3. ?>


Dzieki za podpowiedz smile.gif
webdice
mysql_num_rows" title="Zobacz w manualu PHP" target="_manual to zło. Korzystaj z COUNT(*):

  1. <?php
  2. $query = mysql_query ("SELECT COUNT(*) as `count` FROM `news`");
  3.  
  4. $row = mysql_fetch_assoc ($query);
  5.  
  6. $numer = $row['count']+1;
  7. ?>
bemol
oki, dzięki, skorzystałem z tego co napisałeś smile.gif
A teraz kolejne pytanie. Wypisuje wszystkie newsy do tabeli (<table>) z tabeli MySQL (`news`).
I teraz chce zrobić tak, żeby wypisywało komunikat "Brak newsów do wyświetlenia." jeśli nie ma rekordów, czyli $row['id'] == 0.

  1. <?php
  2. $show = mysql_query("SELECT * FROM news ORDER BY id DESC");
  3. while ($row = mysql_fetch_array($show)) {
  4. echo '<TABLE><TR>';
  5. echo "<TD>Numer newsa:</TD><TD>".$row['id']."</TD>";
  6. echo '</TR>';
  7. echo '<TR>';
  8. echo "<TD>Data newsa:</TD><TD>".$row['data']."</TD>";
  9. echo '</TR>';  
  10. echo '<TR>';
  11. echo "<TD>Autor newsa:</TD><TD>".$row['autor']."</TD>";
  12. echo '</TR>';
  13. echo '<TR>';
  14. echo "<TD>Treść newsa:</TD><TD>".$row['tresc']."</TD>";
  15. echo '</TR>';
  16. echo '</TABLE>';
  17. if ($row['id'] == null) echo "Brak newsów do wyświetlenia.";
  18. }
  19. ?>


Próbowałem na różne sposoby i nie chce mi wyjść :/
webdice
Skorzystaj z mojego zapytania, i zamiast

  1. <?php
  2. if ($row['id'] == 0) { ... }
  3. ?>



zrób tak:

  1. <?php
  2. if ($row['count'] == 0) { ... }
  3. ?>
dadexix
Kod
mysql_num_rows to zło
nie prawda.. czuje się urażony... a co jeśli wykonuje zapytanie chce sprawdzić ilość rekordów pobranych a potem operować przez np. mysql_fetch_array na wyniku? Hm? 2 zapytania? chłopaka nauczysz że to jest zło i potem będzie na dole strony "zapytań do SQL: 1923"
bemol
Poprzedni problem rozwiązany, a co z takim plikiem:
  1. <?php
  2. error_reporting(E_ALL ^ NOTICE);
  3. include('connection.php');
  4. $laczenie = mysql_connect(SERWER, ADMIN, PASS) or die ('Błąd połączenia z bazą danych MySQL.');
  5. $laczenie2 = mysql_select_db(DB) or die ('Błąd podczas wybierania bazy danych.');
  6.  
  7. $ilosc_newsow = $_POST['ilosc_newsow'];
  8. $active = $_POST['active'];
  9. $type = $_POST['type'];
  10. $rozmiar = $_POST['rozmiar'];
  11. $min_rozmiar = $_POST['min_rozmiar'];
  12.  
  13. $query = "UPDATE config SET active='$active' type='$type' ilosc_newsow='$ilosc_newsow' rozmiar='$rozmiar' min_rozmiar='$min_rozmiar' WHERE id=1";
  14. $wynik = mysql_query($query);
  15. /*if ($wynik) {echo "Zmiany pomyślnie zachowane.";
  16. }
  17. else "Błąd podczas zmiany ustawień.";
  18. var_dump($query);*/
  19. ?>


Czy są tutaj jakieś błędy logiczne? W tabeli nie nadpisuje danych :/
webdice
  1. <?php
  2. active='$active', type='$type', ...
  3. ?>


Zapomniałeś o przecinkach.
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.