Drukowana wersja tematu

Kliknij tu, aby zobaczyć temat w orginalnym formacie

Forum PHP.pl _ Przedszkole _ [php][mysql] Wyciąganie danych do petli

Napisany przez: bemol 22.12.2007, 10:45:05

  1. <?php
  2. 7. $query = "SELECT * FROM users";
  3. 8. while ($row = http://www.php.net/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

Napisany przez: cornholio666 22.12.2007, 10:46:15

brakuje ci mysql_query()

Napisany przez: Sadu2 22.12.2007, 10:49:48

A tak będzie działać?

  1. <?php
  2. $query = http://www.php.net/mysql_query("SELECT * FROM users");
  3. while ($row = http://www.php.net/mysql_fetch_array($query))
  4. {
  5. $pass_db[] = $row['pass'];
  6. $login_db[] = $row['login'];
  7. }
  8. ?>

Napisany przez: bemol 22.12.2007, 18:26:28

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ź.

Napisany przez: phpion.com 22.12.2007, 18:33:46

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ę.

Napisany przez: 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)

Napisany przez: webdicepl 22.12.2007, 18:42:59

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.

Napisany przez: bemol 22.12.2007, 18:49:18

ok, wyłączyłem auto_increment i rozwiązałem to tak:

  1. <?php
  2. $query = http://www.php.net/mysql_query ("SELECT id FROM news");
  3. $numery = http://www.php.net/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

Napisany przez: webdicepl 22.12.2007, 19:06:28

http://pl.php.net/mysql_num_rows to zło. Korzystaj z COUNT(*):

  1. <?php
  2. $query = http://www.php.net/mysql_query ("SELECT COUNT(*) as `count` FROM `news`");
  3.  
  4. $row = http://www.php.net/mysql_fetch_assoc ($query);
  5.  
  6. $numer = $row['count']+1;
  7. ?>

Napisany przez: bemol 22.12.2007, 19:48:39

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


Próbowałem na różne sposoby i nie chce mi wyjść :/

Napisany przez: webdicepl 22.12.2007, 23:18:10

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. ?>

Napisany przez: dadexix 23.12.2007, 04:00:00

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"

Napisany przez: bemol 23.12.2007, 15:20:05

Poprzedni problem rozwiązany, a co z takim plikiem:

  1. <?php
  2. http://www.php.net/error_reporting(E_ALL ^ NOTICE);
  3. include('connection.php');
  4. $laczenie = http://www.php.net/mysql_connect(SERWER, ADMIN, PASS) or http://www.php.net/die ('Błąd połączenia z bazą danych MySQL.');
  5. $laczenie2 = http://www.php.net/mysql_select_db(DB) or http://www.php.net/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 = http://www.php.net/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 :/

Napisany przez: webdicepl 23.12.2007, 15:28:47

  1. <?php
  2. active='$active', type='$type', ...
  3. ?>


Zapomniałeś o przecinkach.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)