Запрос на SELECT
Страницы: 1
Запрос на SELECT
Здравствуйте. Прошу помочь с реализацией простого, но в тоже время сложного для меня запроса в базу данных. Есть, например, новости с такими ID:
56322
55304
54788
53485
49264
48076
43958


Нужно выполнить запрос для вывода сначала новостей, у которых ID меньше 50000 по списку сверху вниз, а только затем у которых больше 50000, но также по списку сверху вниз и при этом итог нужно ограничить 5-тю результатами. В общем результат должен быть такой:
49264
48076
43958
56322
55304

Очень прошу помочь, не получается составить такой запрос. Буду очень-очень благодарен.
Изменено: AlexanderKoroten - 13 Июня 2014 19:34
Код
SELECT id FROM `table` WHERE `id` < 50000 ORDER BY `id` DESC LIMIT 3;

SELECT id FROM `table` WHERE `id` > 50000 ORDER BY `id` DESC LIMIT 2;
Результат запросов в разные переменные и вывод = три до 50 - по нисходящей, 2 - после 50, по нисходящей.


Наверное)
Coder, ну это я так понимаю два отдельных запроса? У меня сейчас подобное уже реализовано, но хотелось бы одним запросом обойтись.
Цитата
AlexanderKoroten пишет:
но хотелось бы одним запросом обойтись
А зачем? Соединение одно, нагрузка несущественна - у вас по-любому будет пробежка в два этапа, имхо.
Coder, да это скорее для себя самого. Хочется как-то унифицировать код, а то получается задвоение функции вывода результата на сайт. Просто бывало выполнял гораздо более сложные запросы, а в этой ситуации просто ступор какой-то. Может решение очевидное, а я его не вижу.
Понятно) Можно и в одну функцию все напихать - только смысла, по сравнению с каждой по своей задаче, вроде не много, имхо.

Но, - если тревожит, то таки надо пытаться)

Удачи)
Coder, спасибо. Кто ещё может поможет идеями?
Цитата
AlexanderKoroten пишет:
Coder, спасибо
Да не сделал ничего... Пожалуйста)
Используйте оператор UNION - данный оператор используется для объединения запросов SELECT.



Код
SELECT id FROM table WHERE id < 50000 ORDER BY id DESC LIMIT 3
UNION
SELECT id FROM table WHERE id > 50000 ORDER BY id DESC LIMIT 2;
В действительности вы знаете предмет только в той степени, в которой можете научить других, с тем чтобы они его поняли и применили в своей жизни.
Андрей П-Студия, к сожалению UNION с сортировкой в таком виде не работает. Работает только если общую сортировку сделать, но тогда она весь принцип вывода меняет.
Если ваш запрос нельзя выполнить с помощью простых операторов SQL, значит ваше решение самое оптимальное.
Т.к. все остальные решения со сложными комбинациями операторов только утяжелят Код!

З.Ы.: вот тут есть какое то решение по поводу совместимости UNION и ORDER BY:


Код
SELECT ....

FROM  (SELECT TOP 1 ...

FROM ...

ORDER BY ...) AS x

UNION ALL

SELECT ....

FROM  (SELECT TOP 4 ...

FROM ...

ORDER BY ... DESC) AS y
Изменено: Андрей П-Студия - 13 Июня 2014 23:04
Андрей П-Студия, ооооо, это просто невероятно!! Сработало. Именно этот запрос и выводит новости в том порядке, в котором мне и хотелось. Огромное Вам спасибо!!
P.S. Если кто будет мимо проходить поставьте пользователю Андрей П-Студия плюс, а то у меня отрицательная репутация не позволяет это сделать.
Страницы: 1
Похожие темы:
Читают тему (гостей: 1, пользователей: 0, из них скрытых: 0)
Новые темыОбъявленияСвободное общение
12:25 Бесплатное расширение для Chrome — проверка ссылок прямо на странице 
12:23 Бесплатное получение бэклинков 
12:21 Яху Скаут и китайцы - есть там вообще жизнь для новичка в 2026? 
12:15 Ап выдачи Яндекса 8 апреля - есть движение, но интереснее что творится с AI-ответами Google 
12:13 Хватит ныть про смерть сайтов и нейроответы - почему мы всё еще в деле 
12:11 С чего сейчас проще начать? 
12:09 Биржи ссылок в 2026 - реально ли новичку с одним сайтом поднять копейку? 
15:41 Trustpilot Reviews | Подниму рейтинг вашей компании 
15:40 Продвижение YouTube видео в топ поиска | Любой тип контента | Гарантия результата 
15:39 №1 Рассылка / Инвайтинг [TELEGRAM] | Приватный метод 
15:39 Установка|Настройка|Доработка|Наполнение сайтов|Дизайн|3D|Видеомонтаж 
23:36 GoodsMoney.io 
23:35 Volna.money 
14:48 Monitex: Мониторинг с кэшбэком 80% в USDT 
21:24 Точные прогнозы на футбол 
21:05 Сайты Рунета 
15:42 Список обновленных тем пуст... 
15:39 Всех с праздником! 
14:31 молодильные яблоки и живая вода 
13:24 Во Франции начали штрафовать за IPTV - до 300-400 евро уже прилетает обычным пользователям 
12:20 Ням-ням! - 8 деликатесов, которые когда-то ели только бедные люди