Запрос на 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)
Новые темыОбъявленияСвободное общение
00:35 Взломы и уязвимости в 2026 - реально ли новичку защитить свой блог? 
00:33 биржи в 26-м окончательно сдохли или кто-то еще ковыряет этот шлак? 
23:53 Легкая тема для Вордпресса в 2026 - чтобы и красиво, и быстро? 
22:40 Штрафы РСЯ за скорость - выкинет ли Яндекс сайт на дешевом хостинге? 
21:50 Апдейт 14 апреля: ощущение, что режет не только выдача 
00:47 В Яндексе позиции держатся, а трафик проседает - стало заметно сильнее 
00:09 Бесплатное расширение для Chrome — проверка ссылок прямо на странице 
21:47 Продам домен 28z.ru 
15:56 Продам Домены .COM с историей трафика. 
13:24 AllCharge.online. Современный, быстрый и надёжный обменник 
13:12 Linken Sphere – браузер-антидетект нового поколения 
11:10 Мониторинг обменников Сrypto-scout.io 
10:11 BestChange – обменивать электронную валюту можно быстро и выгодно 
08:55 Monitex: Мониторинг с кэшбэком 80% в USDT 
23:15 молодильные яблоки и живая вода 
22:42 Всех с праздником! 
22:34 90% людей живут не своей жизнью - вы тоже? 
22:14 С юмором по жизни! 
22:09 Во Франции начали штрафовать за IPTV - до 300-400 евро уже прилетает обычным пользователям 
21:55 В жительница Китая каждый день общается с ИИ-клоном сына и не знает, что он умер 
16:34 Франция уходит с Windows на Linux - это реально тренд или просто политика?