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

Форум MySQL

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

 

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

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

тема: Подсчет всех записей
 
 автор: BLACK   (22.07.2010 в 12:02)   письмо автору
 
 

Доброго времени суток.

Подскажите каким запросом можно посчитать кол-во всех записей в неограниченной вложенности категорий.

Вот структура таблицы неограниченных категорий:
id | uid | name


Вот структура таблицы записей:
id | id_category | text


Вот код в котором идет подсчет именно в выбранной категории:

<?php
$sql_category 
mysql_query("SELECT * FROM category WHERE uid < '1' ORDER BY name");
while(
$category mysql_fetch_assoc($sql_category)){
$col_file mysql_result(mysql_query("SELECT COUNT(*) FROM article WHERE id_category='$category[id]'"), 0);
echo 
'<a href="">'.$category['name'].'</a> ['.$col_file.']';
}
?>


А как посчитать все записи во вложенности категорий?

  Ответить  
 
 автор: Trianon   (22.07.2010 в 12:08)   письмо автору
 
   для: BLACK   (22.07.2010 в 12:02)
 

>Вот структура таблицы неограниченных категорий:
>id | uid | name

Что. Это. Значит.

  Ответить  
 
 автор: BLACK   (22.07.2010 в 12:19)   письмо автору
 
   для: Trianon   (22.07.2010 в 12:08)
 

Вот пример заполненности категорий:

1 | 0 | Первая
2 | 0 | Вторая
3 | 0 | Третья
4 | 1 | Первая1
5 | 1 | Первая2
6 | 3 | Третья1
7 | 4 | Первая11


Это вывод:

Первая
 -Первая1
   -Первая11
 -Первая2
Вторая
Третья
 -Третья1


Вот и необходим подсчет статей в каждой (под)категории.

  Ответить  
 
 автор: Trianon   (22.07.2010 в 14:28)   письмо автору
 
   для: BLACK   (22.07.2010 в 12:19)
 

>id | uid | name
Что. Это. Значит.

Подсчет записей, входящих в некоторую иерархию списка смежности делается так:
в цикле
SELECT id FORM category WHERE uid IN ($a)

с добавлением полученного набора ключей в список.

после чего определяется количество связанных объектов.
SELECT COUNT(*) FORM article WHERE id_category IN( $list)

  Ответить  
 
 автор: BLACK   (22.07.2010 в 15:53)   письмо автору
 
   для: Trianon   (22.07.2010 в 14:28)
 

Неограниченная вложенность...
Вот как бы такой цикл составить?

Но все таки спасибо, попробую что нибудь придумать.

  Ответить  
 
 автор: Trianon   (22.07.2010 в 16:08)   письмо автору
 
   для: BLACK   (22.07.2010 в 15:53)
 

http://softtime.ru/forum/read.php?id_forum=3&id_theme=56816

  Ответить  
Rambler's Top100
вверх

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