Запрос на 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)
Новые темыОбъявленияСвободное общение
19:02 Gambling Craft - гемблинг по белому 
17:03 LOSPOLLOS.COM - Конвертим по рецепту Хайзенберга. Dating, Mainstream, Binary Options 
15:51 Яндекс-ап 20 марта и похороны ChatGPT, Claude и Gemini. Считаем убытки 
10:16 Бесплатное расширение для Chrome — проверка ссылок прямо на странице 
10:15 ИКС Яндекс АПдейт 1 апреля 2026. Обновлён алгоритм расчёта 
10:12 Gmail разрешил менять основной адрес - теперь можно убрать старые ники без переноса аккаунта 
18:01 Раскрутка форума 
16:02 Bardo — Бюро развития и координации цифровых операций. 
15:55 Русские народные сказки - оцените! 
14:32 [UPDATE] CryptoMonitor — обмен BTC, USDT, XMR | актуальная тема сервиса 
13:29 MIG-OBMEN.net — Быстрый и надежный обмен цифровых активов 
11:08 BMB exchange - обменник криптовалют, в котором всё под контролем 
10:52 Современный скрипт обменника электронных валют 
08:50 Monitex: Мониторинг с кэшбэком 80% в USDT 
17:25 молодильные яблоки и живая вода 
15:49 Огородники 
00:06 Точные прогнозы на футбол 
16:25 8 марта: желаю аптайма 99.9% и e-e-a-t без локов 
22:45 С юмором по жизни! 
15:42 Голландцы влепили Grok по яйцам - теперь нельзя раздевать реальных людей, штраф 100к евро в день 
07:17 Почему не обновляется счетчик ИКС (индекса качества сайта)