Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
PHP Puzzles. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5/6. В подлиннике. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Сложный подсчет
 
 автор: BaSh   (21.10.2007 в 23:14)   письмо автору
 
 

Есть 2 поля

+--------+--------+
| pole1 | pole2 |
+--------+--------+
| 1 | 1 |
| 2 | 1 |
| 3 | 2 |
| 4 | 6 |
| 5 | 6 |
| 6 | 5 |
| 7 | 6 |
| 8 | 10 |
| 9 | 8 |
+--------+--------+

SELECT COUNT(*) FROM table WHERE pole2=1
выведет 2, то есть подсчитает 2 значения
SELECT COUNT(*) FROM table WHERE pole2=6
выведет 3 и подсчитает 3 значения
SELECT COUNT(*) FROM table WHERE pole2=10
выведет 1 и подсчитает 1 значение

Нужно:
Составить такой запрос чтобы получить подсчет всех значений, где значение из pole1 также равны(передаются) в pole2, например:
SELECT ... COUNT(*) FROM table WHERE pole2=1.... чтобы вывело 3 и подсчитало 3 значения поля
SELECT ... COUNT(*) FROM table WHERE pole2=6.... чтобы вывело 4 ...
SELECT ... COUNT(*) FROM table WHERE pole2=10.... выводило бы 2 ...
закономерность в том, что значения попадают из первого поля во второе, и нужно подсчитать их, то есть, например, по первому запросу:
известно значение pole2 - 1, ему соответсвует также число 2 из pole1, и есть такое значение в pole2 которое тоже равно 2, вот эти все строки полей мне и нужно подсчитать.
По второму: известно 6 из pole2, в pole1 есть 5, также есть 5 в pole2 - эту строку тоже нужно добавить к подсчету.
В третьем: есть 10, но и есть 8 в pole1, которое также присутствует в pole2...
Добавлю что pole1 является первичным ключем, и количество таких вхождений, которые я описал может быть сколько угодно по всей таблице.

Заранее благодарю за помощь!

   
 
 автор: BaSh   (22.10.2007 в 15:17)   письмо автору
 
   для: BaSh   (21.10.2007 в 23:14)
 

неужели никто не может подсказать... ((((

   
 
 автор: EXP   (22.10.2007 в 19:51)   письмо автору
 
   для: BaSh   (22.10.2007 в 15:17)
 

непонятно известны-ли заранее значения, количество повторов которых нужно вывести .
Если известно то можно оператором UNION объеденить несколько запросов.

   
 
 автор: BaSh   (22.10.2007 в 20:16)   письмо автору
 
   для: EXP   (22.10.2007 в 19:51)
 

mysql_query("SELECT COUNT(*) FROM table WHERE pole2=".$_GET['kol']);
методом get передается значение второго поля, оно известно лишь одно - начальное, количество повторов вхождений может быть каким угодно...
>>>Если известно то можно оператором UNION объеденить несколько запросов.
Если можно, поподробней, по справочнику всего один пример идет, не до конца разобрался...

   
 
 автор: oradev   (22.10.2007 в 20:23)   письмо автору
 
   для: BaSh   (22.10.2007 в 20:16)
 

ничего сложного не вижу. Сначала подсчитываете как вы уже сказали кол-во зачений с текущим pole2 Затем полсчитываете кол-во значений у которых pole1 = pole2. Объединяйте и подсчитываете общее кол-во.

   
 
 автор: EXP   (22.10.2007 в 21:52)   письмо автору
 
   для: oradev   (22.10.2007 в 20:23)
 

совсем запутался чего надо посчитать :)
думал что надо вывести например сколлько значений pole2 равно например 1, 2 и 6

SELECT COUNT(*) FROM tab WHERE pole2 = 1
UNION ALL
SELECT COUNT(*)  FROM tab WHERE pole2 = 2
UNION ALL
SELECT COUNT(*)  FROM tab WHERE pole2 = 6
будет полученно три ряда с цифрой результата
UNION, UNION ALL требует только что-бы колл-во и тип результатов запросов были одинаковые, работает только с SELECT . больше ничего и не знаю :)

так то-же самое одним рядом

SELECT (SELECT COUNT(*) FROM tab WHERE pole2 = 1) AS res1,
(SELECT COUNT(*)  FROM tab WHERE pole2 = 2) AS res2,
(SELECT COUNT(*)  FROM tab WHERE pole2 = 6) AS res3


можно так-же подсчитать сколько pole1=pole2 , если надо

стандартную функцию не нашёл такую которая умеет считать сколько раз встречается каждое значение

   
 
 автор: oradev   (22.10.2007 в 22:03)   письмо автору
 
   для: BaSh   (22.10.2007 в 20:16)
 

Для pole2 = 1 :

select count(*) from(
  select pole2 from t 
  union all 
  select t.pole2 from t
    join t t2 on t.pole1=t2.pole2 and t.pole1<>t.pole2 
)
where pole2 = 1

   
 
 автор: BaSh   (22.10.2007 в 22:41)   письмо автору
 
   для: oradev   (22.10.2007 в 22:03)
 

большое Вам спасибо!

   
 
 автор: oradev   (22.10.2007 в 22:52)   письмо автору
 
   для: BaSh   (22.10.2007 в 22:41)
 

на здоровье!:)

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования