Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Рандомная выборка из БД с ORDER BY

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Elegant
Отправлено: 09 Февраля, 2015 - 16:36:26
Post Id



Частый гость


Покинул форум
Сообщений всего: 151
Дата рег-ции: Май 2012  


Помог: 1 раз(а)




ДД! Есть таблица
что то вроде
ID NAME STATUS
1 qqq 1
2 www 1
3 eee 2
4 rrr 2
5 tttt 2

я вывожу их так:
$sql = "SELECT * FROM `table`
ORDER BY `table`.`status` DESC ";

Мне выводится сначала записи к статус 2 а потом 1
...
А вот сама задача
Мне надо что бы выборка была рандомная...т.е. вывел сначала записи где статус 2 но рандомно,а потом где статус 1(можно не рандомно).

(Отредактировано автором: 09 Февраля, 2015 - 16:42:52)

 
 Top
Мелкий Супермодератор
Отправлено: 09 Февраля, 2015 - 16:54:48
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




CODE (SQL):
скопировать код в буфер обмена
  1. ORDER BY `status` DESC, rand()


Для таблиц покрупнее начнутся грабли и костыли с производитльностью вплоть до сортировки силами PHP.


-----
PostgreSQL DBA
 
 Top
Elegant
Отправлено: 09 Февраля, 2015 - 17:17:16
Post Id



Частый гость


Покинул форум
Сообщений всего: 151
Дата рег-ции: Май 2012  


Помог: 1 раз(а)




Мелкий пишет:
CODE (SQL):
скопировать код в буфер обмена
  1. ORDER BY `status` DESC, rand()


Для таблиц покрупнее начнутся грабли и костыли с производитльностью вплоть до сортировки силами PHP.


Спасибо! Помогло...таблица на 10000 записей у меня
 
 Top
Elegant
Отправлено: 10 Февраля, 2015 - 08:10:32
Post Id



Частый гость


Покинул форум
Сообщений всего: 151
Дата рег-ции: Май 2012  


Помог: 1 раз(а)




А можно рандомом размешать только те записи где есть СТАТУС 2, а где статус 1 допустим по алфавиту?
 
 Top
Мелкий Супермодератор
Отправлено: 10 Февраля, 2015 - 09:49:09
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


Помог: 618 раз(а)




Например
CODE (SQL):
скопировать код в буфер обмена
  1. ORDER BY `status` DESC, IF (`status`=2, rand(), name)


-----
PostgreSQL DBA
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB