Выборка с базы данных MySQL по пустому\не пустому пол.

программирование php MySQL базы данных sql

Есть такой запрос
SELECT * FROM `users` ORDER by `users`.`uid` DESC LIMIT 0, 60
Достает как надо. Но в таблице есть поле `ava`, хочу сортировать пользователей по наличию аватарки, чтобы сначала шли те, у кого она есть, а потом уже те, у кого ее нет
В случае, если ава есть, в поле прописан адрес на картинку, а если нет авы, то поле пустое

Если напишу `ava`!='' то выведет только с аватаркой, а те у кого ее нет в выборку не попадут вообще

Заранее спасибо
Ответы:
получайте результат запроса к базе, а потом уже его сортируйте.
смотрите в документации по php как сортируют массивы.
Можно так сделать: ORDER BY IF(`users`.`ava` = '', 1, 0), `users`.`uid`
Конечно, если под пустым полем понимается NULL, то нужно соответствующим образом прописать условие (`ava` IS NULL).


10 лет назад

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

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

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