Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [mysql] COUNT z wielu tabel naraz
skowron-line
post
Post #1





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

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


czy mozliwe jest zrobienie w jednym zapytaniu zliczanie id z 3 tabel??
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 5)
batman
post
Post #2





Grupa: Moderatorzy
Postów: 2 921
Pomógł: 269
Dołączył: 11.08.2005
Skąd: 127.0.0.1




Jest możliwe (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg)

  1. SELECT sum(ilosc) FROM ( SELECT count(t1.id1) AS ilosc FROM t1 UNION
  2. SELECT count(t2.id2) AS ilosc FROM t2 ) AS razem


gdzie:
t1 - tabela pierwsza,
t2 - tabela druga,
id1 - zliczane pole z pierwszej tabeli
id1 - zliczane pole z drugiej tabeli
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%)
-----


@Batman wzorujac sie na tym co napisales zrobilem cos takiego
  1. SELECT COUNT(`user`.id_user) AS u FROM `user` UNION
  2. SELECT COUNT(galerie.id_galerie) AS g FROM galerie UNION
  3. SELECT COUNT(foto.id_foto) AS f FROM foto


ale chyba cos zj**lem bo jak daje
  1. <?php
  2. print_r($row);
  3. ?>


to dostaje

Kod
Array ( [0] => 1 [u] => 1 ) Array ( [0] => 0 [u] => 0 )
Go to the top of the page
+Quote Post
batman
post
Post #4





Grupa: Moderatorzy
Postów: 2 921
Pomógł: 269
Dołączył: 11.08.2005
Skąd: 127.0.0.1




Zamiast COUNT(`user`.id_user) napisz COUNT(g). W drugim select nie jest już chyba potrzebny AS. Powinno pomóc.

edit
Jeśli nie pomoże, to w drugim AS też wpisz AS g

Ten post edytował batman 24.11.2006, 10:53:54
Go to the top of the page
+Quote Post
skowron-line
post
Post #5





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

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


edit:

  1. SELECT COUNT(user.id_user), COUNT(galerie.id_galerie), COUNT(foto.id_foto) FROM user, galerie, foto


edit::

ale cos nie tak chyba zrobilem

Ten post edytował skowron-line 24.11.2006, 13:12:50
Go to the top of the page
+Quote Post
batman
post
Post #6





Grupa: Moderatorzy
Postów: 2 921
Pomógł: 269
Dołączył: 11.08.2005
Skąd: 127.0.0.1




Struktura tabel:

  1. --
  2. -- Struktura tabeli dla `t1`
  3. --
  4.  
  5. CREATE TABLE `t1` (
  6. `id1` int(11) NOT NULL AUTO_INCREMENT,
  7. `text1` varchar(10) NOT NULL,
  8. PRIMARY KEY (`id1`)
  9. ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=7 ;
  10.  
  11. -- --------------------------------------------------------
  12.  
  13. --
  14. -- Struktura tabeli dla `t2`
  15. --
  16.  
  17. CREATE TABLE `t2` (
  18. `id2` int(11) NOT NULL AUTO_INCREMENT,
  19. `text2` varchar(12) NOT NULL,
  20. PRIMARY KEY (`id2`)
  21. ) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=5 ;


Zapytanie (takie samo jak w moim pierwszym poście):
  1. SELECT sum(ilosc) FROM ( SELECT count(t1.id1) AS ilosc FROM t1 UNION SELECT count(t2.id2) AS ilosc FROM t2 ) AS razem


Zwraca 10 wierszy (w pierwszej tabeli mam 6, w drugiej 4).
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: 23.08.2025 - 12:06