Возможно ли в MySQL указать последовательность вывода строк в одном запросе?

MySQL бд вывод запрос

К примеру, нужно извлечь строки с id 102, 27, 256, 1, 80 - именно в таком порядке.

Есть как вариант отправлять несколько запросов или несколько запросов в одном с помощью union (хотя страшно представить, что будет, если id будет хотя бы 50) или завести отдельный столбец, где будут храниться порядковый номер вывода (тоже не подходит, так как строки повторяются в различных - в одном 102 будет первым, а в во втором пятым.

Примечание:
mokurai - нет - нужен вывод именно в том порядке, который задается в запросе.

SELECT * FROM `messages` WHERE id in (30, 1, 20, 3, 10)

все равно выведет по порядку
Ответы:
А такая конструкция не подойдёт?
SELECT *
FROM [database]
WHERE [field] IN ('1,2,3')
Все выходы из ситуации вы перечислили.
Ну или можно на стороне php (или чего у вас там) решить.
есть find_in_set()
но я бы вообще не заморочивался, а сортировал при получении.


15 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.