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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Объединение трех таблиц MySQL

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Без описания
Css-community
Отправлено: 28 Февраля, 2012 - 15:26:19
Post Id


Новичок


Покинул форум
Сообщений всего: 6
Дата рег-ции: Февр. 2012  
Откуда: Саранск


Помог: 0 раз(а)




Вообщем есть три таблицы:

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.

Думаю что смысл понятен, что нужно для каждой категории форума узнать сколько в ней топиков и постов.
Можно ли это реализовать одним запросом и не прибегая к подзапросам, да бы оптимизировать запрос.
 
 Top
ugin_root
Отправлено: 28 Февраля, 2012 - 15:43:52
Post Id


Частый гость


Покинул форум
Сообщений всего: 134
Дата рег-ции: Май 2011  
Откуда: Киргизия


Помог: 5 раз(а)




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

(Отредактировано автором: 28 Февраля, 2012 - 15:49:20)

 
 Top
Panoptik
Отправлено: 28 Февраля, 2012 - 15:47:42
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2493
Дата рег-ции: Нояб. 2011  
Откуда: Одесса, Украина


Помог: 131 раз(а)




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`

(Отредактировано автором: 28 Февраля, 2012 - 15:48:41)



-----
Just do it
 
 Top
Okula
Отправлено: 28 Февраля, 2012 - 15:51:41
Post Id



Участник


Покинул форум
Сообщений всего: 1389
Дата рег-ции: Окт. 2010  


Помог: 42 раз(а)




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 такой сложный.
 
 Top
snikers987
Отправлено: 28 Февраля, 2012 - 16:00:25
Post Id



Участник


Покинул форум
Сообщений всего: 1239
Дата рег-ции: Сент. 2011  
Откуда: Крым


Помог: 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


-----
Когда всматриваешься в тёмную бездну, учти, что кто-то может смотреть на тебя из неё...
 
My status
 Top
Okula
Отправлено: 28 Февраля, 2012 - 16:04:28
Post Id



Участник


Покинул форум
Сообщений всего: 1389
Дата рег-ции: Окт. 2010  


Помог: 42 раз(а)




snikers987, как бы JOIN работает так же, так что разницы мало, что алиасинг, что джоин Улыбка
 
 Top
ugin_root
Отправлено: 28 Февраля, 2012 - 16:12:13
Post Id


Частый гость


Покинул форум
Сообщений всего: 134
Дата рег-ции: Май 2011  
Откуда: Киргизия


Помог: 5 раз(а)




Okula
совсем не в вашем случае. вы по сути делаете 3 альяса, а хватит и 2-х Улыбка
 
 Top
Css-community
Отправлено: 29 Февраля, 2012 - 06:49:19
Post Id


Новичок


Покинул форум
Сообщений всего: 6
Дата рег-ции: Февр. 2012  
Откуда: Саранск


Помог: 0 раз(а)




Что то не один из выше указанных запросов не дал положительного результата. Может быть делать так, вначале группировать по топикам и считывать количество постов, в потом уже группировать по категориям и суммировать количество постов.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB