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 :: Версия для печати :: Смешанный запрос из двух таблиц
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » Смешанный запрос из двух таблиц

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

1. SunChase - 18 Сентября, 2010 - 21:05:46 - перейти к сообщению
Здравствуйте.

Хочу сделать чтото вроде новостной ленты событий,которая составляется из значений двух таблиц,а именно Коментарии и Рейтинги.

Отсюда и вопрос : можно ли в запросе,берущем данные одновременно из двух таблиц, сделать сортировку по дате (коментария или рейтинга)...да и вообще получить вывод информации такого типа :

1.Комментарий .... дата : 18.09.2010 21:02
2.Рейтинг .... дата : 15.09.2010 20:05
3.Коментарий ....
и т .д.
2. HotBird - 18 Сентября, 2010 - 22:24:53 - перейти к сообщению
CODE (SQL):
скопировать код в буфер обмена
  1. (SELECT comment,date FROM comments )
  2. UNION
  3. (SELECT rating,date FROM ratings )
  4. ORDER BY date DESC
3. SunChase - 18 Сентября, 2010 - 22:26:55 - перейти к сообщению
Спасибо.Только вот ещё такой вопрос :
если в двух таблицах столбец с датой назван по своему (com_date,rating_creationdate) то как это правильно написать ?
4. HotBird - 18 Сентября, 2010 - 23:03:11 - перейти к сообщению
Тогда так:
CODE (SQL):
скопировать код в буфер обмена
  1. (SELECT comment,com_date FROM comments )
  2. UNION ALL
  3. (SELECT rating,rating_creationdate FROM ratings )
  4. ORDER BY 2 DESC

Добавил ALL чтобы проводилась выборка всех строк, иначе будут выбиратся только уникальные.
5. SunChase - 18 Сентября, 2010 - 23:33:20 - перейти к сообщению
Таким методом вылазит ошибка "The used SELECT statements have a different number of columns"
6. HotBird - 19 Сентября, 2010 - 00:00:57 - перейти к сообщению
Тогда попробуйте сместить номера столбцов com_date и rating_creationdate к одинаковому значению, а потом указать этот номер в ORDER BY ? DESC
7. SunChase - 19 Сентября, 2010 - 00:45:07 - перейти к сообщению
да тут ошибка вылазит и без применения ORDER BY
8. HotBird - 19 Сентября, 2010 - 01:31:51 - перейти к сообщению
Попробуйте сместить номера столбцов com_date и rating_creationdate к одинаковому значению и столбцы comment и rating тоже к одинаковому значению.

Или ещё вариант создавать временную таблицу копируя туда данные из двух запросов а тогда делать из неё выборку с сортировкой.
9. JustUserR - 19 Сентября, 2010 - 01:45:14 - перейти к сообщению
HotBird Для осуществления вывода значений из различных таблиц БД кототые связываются по некоторому общему критерую возможно использование FULL JOIN-запросов - которое позволяет по сути получить необходимый набор данных с интеграцией столбцов
10. SunChase - 19 Сентября, 2010 - 20:49:08 - перейти к сообщению
Спасибо, но проблема так и нерешилась.
11. JustUserR - 20 Сентября, 2010 - 17:36:41 - перейти к сообщению
SunChase пишет:
Спасибо, но проблема так и нерешилась.
Возможно в вашем случае причиной ошибки в SQL-запросе является не фактическое неправильное его составление - а передаче неправильных интерполируемых параметров в PHP-скрипте - в таком случае полезно использовать диагностический вывод Кроме того для огранизации вывода сложного SQL-запроса можно использовать статические пользовательские SQL-переменные в которые можно сохранит значения промежуточных результатов
12. zardoz - 23 Сентября, 2010 - 00:01:55 - перейти к сообщению
SunChase пишет:
Спасибо, но проблема так и нерешилась.

Конечно не решится, у вас рейтинг под комментарием относится к самому комментарию? Думается что - да. А как они связаны в запросе? Никак.
Выводить нужно связав их либо подзапросом либо JOIN'ом...
Для подробностей нужны структуры таблиц comments и ratings.

С уважением.
13. JustUserR - 23 Сентября, 2010 - 16:54:51 - перейти к сообщению
zardoz пишет:
А как они связаны в запросе? Никак.
В принципе для осуществления вывода несвязанной информации из Бд в едином запросе возможно использовать систему alias-инга полей - в таком случае названия колонок с данными будут идентичными и для разденеия строк может использовать отденое константое выражение - определяющая принадлежность текущего информационного поля к определенному классу выборки
14. zardoz - 23 Сентября, 2010 - 17:37:07 - перейти к сообщению
JustUserR, приведите самый легкий пример.
Мне кажется мы о разных вещах говорим.

С уважением.
15. JustUserR - 24 Сентября, 2010 - 00:41:55 - перейти к сообщению
zardoz пишет:
JustUserR, приведите самый легкий пример.
Мне кажется мы о разных вещах говорим
В приведенном выше сообщении имелась в виду реализация вывода разнородной информации в SQL-запроса путем явного приведения ее в обший вид - такой подход демонстрирует следующий пример
CODE (text):
скопировать код в буфер обмена
  1. (SELECT cm_field1 AS P0, cm_field2 AS P1, "comments" AS TP FROM comments ) UNION
  2. (SELECT rt_field1 AS P0, rt_field2 AS P1, "ratings" AS TP FROM ratings )

 

Powered by ExBB FM 1.0 RC1