Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Объединение трех таблиц MySQL
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » Объединение трех таблиц MySQL

Страниц (1): [1]
 

1. Css-community - 28 Февраля, 2012 - 15:26:19 - перейти к сообщению
Вообщем есть три таблицы:

1) categories
id_category | name_category
-------------------------------- --

2) topics
id_topic | id_category | name_topic
-------------------------------- --

3) posts
id_post | id_topic | text
-------------------------------- --

Нужно сделать запрос, который выводил все поля из таблицы categories, количество полей в таблице topics по ключу id_category и количество записей в таблице posts по ключу id_topic.

Думаю что смысл понятен, что нужно для каждой категории форума узнать сколько в ней топиков и постов.
Можно ли это реализовать одним запросом и не прибегая к подзапросам, да бы оптимизировать запрос.
2. ugin_root - 28 Февраля, 2012 - 15:43:52 - перейти к сообщению
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT
  2.     categories.*,
  3.     count(topics.id_topic) AS count_topic,
  4.     COUNT(posts.id_post ) AS count_post
  5. FROM
  6.     categories
  7.         LEFT OUTER JOIN topics ON  topics.id_category = categories.id_category
  8.         LEFT OUTER JOIN posts ON posts.id_topic = topics.id_topic
  9. GROUP BY categories.id_category
3. Panoptik - 28 Февраля, 2012 - 15:47:42 - перейти к сообщению
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT `c`.*, COUNT(`t`.`id`) AS `topics`, COUNT(`p`.`id`) AS `posts` FROM `categories` AS `c`
  2. LEFT JOIN `topics` AS `t` ON `t`.`id_category` = `c`.`id`
  3. LEFT JOIN `posts` AS `p` ON `p`.`id_topic` = `t`.`id`
  4. GROUP BY `t`.`category_id`
4. Okula - 28 Февраля, 2012 - 15:51:41 - перейти к сообщению
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT a.*,
  2. (SELECT COUNT(*) FROM `topics`
  3.     WHERE `id_category`=a.`id_category`) AS `col_topics`,
  4. (SELECT COUNT(c.*) FROM `topic` AS b, `posts` AS c
  5.     WHERE b.`id_category`=a.`id_category` AND c.`id_topic`=b.`id_topic`) AS `col_posts`
  6. FROM `categories` AS a

Должно работать, проверь. Но мне кажется было бы лучше выполнить несколько запросов чем 1 такой сложный.
5. snikers987 - 28 Февраля, 2012 - 16:00:25 - перейти к сообщению
Okula пишет:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT a.*,
  2. (SELECT COUNT(*) FROM `topics`
  3.     WHERE `id_category`=a.`id_category`) AS `col_topics`,
  4. (SELECT COUNT(c.*) FROM `topic` AS b, `posts` AS c
  5.     WHERE b.`id_category`=a.`id_category` AND c.`id_topic`=b.`id_topic`) AS `col_posts`
  6. FROM `categories` AS a

Должно работать, проверь. Но мне кажется было бы лучше выполнить несколько запросов чем 1 такой сложный.

Подзапросы лучше не использовать с MYSQL < 5.6
6. Okula - 28 Февраля, 2012 - 16:04:28 - перейти к сообщению
snikers987, как бы JOIN работает так же, так что разницы мало, что алиасинг, что джоин Улыбка
7. ugin_root - 28 Февраля, 2012 - 16:12:13 - перейти к сообщению
Okula
совсем не в вашем случае. вы по сути делаете 3 альяса, а хватит и 2-х Улыбка
8. Css-community - 29 Февраля, 2012 - 06:49:19 - перейти к сообщению
Что то не один из выше указанных запросов не дал положительного результата. Может быть делать так, вначале группировать по топикам и считывать количество постов, в потом уже группировать по категориям и суммировать количество постов.

 

Powered by ExBB FM 1.0 RC1