Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> Zliczanie wybranych rekordów...
winnetu
post
Post #1





Grupa: Zarejestrowani
Postów: 33
Pomógł: 0
Dołączył: 2.12.2005
Skąd: Brodnica :)

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


Witam,

Baza danych składa się z kolumn: ID, wynik, tekst, email
kolumna wynik przybiera tylko i wyłącznie trzy wartości: 1, 2, 3
Chciałbym aby skrypt zwracał ilość wierszy z każdą z wartości. Coś na zasadzie:

1 - 10 szt
2 - 20 szt
3 - 30 szt

  1. <?php
  2. $tak = "SELECT wynik FROM sonda WHERE wynik LIKE '1'";
  3. $wynik1 = mysql_query($tak);
  4.  
  5. $nie = "SELECT wynik FROM sonda WHERE wynik LIKE '2'";
  6. $wynik2 = mysql_query($nie);
  7.  
  8. $nie_wiem = "SELECT wynik FROM sonda WHERE wynik LIKE '3'";
  9. $wynik3 = mysql_query($nie_wiem);
  10. ?>


ale nie wiem jak policzyć ile jest, których wierszy :/

Ten post edytował winnetu 22.08.2007, 11:41:25
Go to the top of the page
+Quote Post
mike
post
Post #2





Grupa: Przyjaciele php.pl
Postów: 7 494
Pomógł: 302
Dołączył: 31.03.2004

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


Zapraszam do kursu podstaw SQL.
SUM()
Go to the top of the page
+Quote Post
skowron-line
post
Post #3





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

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


Cytat(winnetu @ 22.08.2007, 10:39:44 ) *
ale nie wiem jak policzyć ile jest, których wierszy :/


Cytat
Zapraszam do kursu podstaw SQL.
SUM()

nie chcem byc zlosliwy ale policzyc to nie zsumowac wiec raczej COUNT()
Go to the top of the page
+Quote Post
mike
post
Post #4





Grupa: Przyjaciele php.pl
Postów: 7 494
Pomógł: 302
Dołączył: 31.03.2004

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


Echh, konsekwencja odpisywania na kilka posów na raz :/
Mój błąd.
Go to the top of the page
+Quote Post
osiris
post
Post #5





Grupa: Zarejestrowani
Postów: 121
Pomógł: 15
Dołączył: 19.07.2007

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


  1. SELECT wynik, COUNT(id)
  2. FROM sonda GROUP BY wynik


Dwie uwagi:
1. Nie uzywaj operatora LIKE tam gdzie nie trzeba, gdyz uniemozliwia on korzystanie z indeksow (nizsza wydajnosc). W Twoich zapytaniach powinienes uzywac operatora porownania (=).
2. Jesli typ pola jest liczba, to przy wstawianiu lub porownywaniu danych nie uzywaj apostrofow. Czyli zamiast wynik = '1', powinno byc wynik = 1. Dowolne znaki ktore otoczone sa apostrofami, traktowane sa przez MySQL jako tekst, przez co serwer MySQL musi niepotrzebnie wykonac konwersje z tekstu do liczby.
Go to the top of the page
+Quote Post
winnetu
post
Post #6





Grupa: Zarejestrowani
Postów: 33
Pomógł: 0
Dołączył: 2.12.2005
Skąd: Brodnica :)

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


Jestem początkujący (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

wymyśliłem coś takiego
  1. <?php
  2. $query = "SELECT COUNT(wynik) FROM sonda WHERE wynik LIKE '3'";
  3. $result = mysql_query($query);
  4. echo $result;
  5. ?>


tylko, że echo $reult, wyświetla "Resource id #3" a powinno wyświetlić się tylko "1" :/
osiris dzięki za rady, wykorzystam Twoją metodę, ale mimo wszystko chciałbym wiedzieć jak mam wyświetlić wynik mojego zapytania na stronie w odpowiedni sposób ?

Chodzi o to, że wpisując zapytanie SQL w konsoli phpMyAdmin wszystko jest OK, ale nie potrafie tego wyniku wyświetlić za pomocą PHP w przeglądarce :/

Ten post edytował winnetu 22.08.2007, 13:58:53
Go to the top of the page
+Quote Post
php programmer
post
Post #7





Grupa: Zarejestrowani
Postów: 1 045
Pomógł: 5
Dołączył: 8.11.2004
Skąd: trójmiasto

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


Ty naprawdę przeczytaj sobie jakiś kurs,
bo wróżką jak widać nie jesteś:

  1. <?php
  2. $query = "SELECT COUNT(wynik) FROM sonda WHERE wynik LIKE '3'";
  3. $result = mysql_query($query);
  4. while ($row = mysql_fetch_array($result)){
  5. print_r($row);
  6. echo '<br /><br />';
  7. }
  8. ?>
Go to the top of the page
+Quote Post

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

 



RSS Aktualny czas: 15.09.2025 - 02:07