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 :: Вывод в хаотичном порядке

 PHP.SU

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


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

> Без описания
ginec
Отправлено: 13 Января, 2011 - 19:14:48
Post Id



Новичок


Покинул форум
Сообщений всего: 41
Дата рег-ции: Окт. 2010  


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




Здравствуйте! Мне необходимо вывести записи в хаотичном виде. Т.е. каждый раз порядок разный. Как это можно сделать? Может есть какие-то команды в SQL?
 
 Top
Мелкий Супермодератор
Отправлено: 13 Января, 2011 - 19:17:42
Post Id



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


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


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




.. order by rand()

при большом количестве записей в таблице будет жрать много ресурсов, там погуглите оптимизацию.


-----
PostgreSQL DBA
 
 Top
ginec
Отправлено: 13 Января, 2011 - 19:44:32
Post Id



Новичок


Покинул форум
Сообщений всего: 41
Дата рег-ции: Окт. 2010  


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




Мелкий спасибо Здорово ! указали куда копать! Прыгаю до потолка Погуглил. Записей будет не более 300-500. Думаю тут это не так страшно.

(Отредактировано автором: 13 Января, 2011 - 19:53:59)

 
 Top
Champion Супермодератор
Отправлено: 13 Января, 2011 - 20:08:25
Post Id



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


Покинул форум
Сообщений всего: 4350
Дата рег-ции: Авг. 2008  
Откуда: Москва


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




SELECT * FROM tbl WHERE id > rand(0, (select max(id) from tbl)) LIMIT 1
UNION ALL
SELECT * FROM tbl WHERE id > rand(0, (select max(id) from tbl)) LIMIT 1
UNION ALL
SELECT * FROM tbl WHERE id > rand(0, (select max(id) from tbl)) LIMIT 1
UNION ALL
SELECT * FROM tbl WHERE id > rand(0, (select max(id) from tbl)) LIMIT 1
...

А лучше хранимую процедуру, чтоб max(id) несколько раз не выбирать
 
 Top
ginec
Отправлено: 17 Января, 2011 - 15:53:38
Post Id



Новичок


Покинул форум
Сообщений всего: 41
Дата рег-ции: Окт. 2010  


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




У меня на сайте пагинация и поэтому использую LIMIT.
Если сделать так, то на страницах может попадаться запись с предыдущей страницы. Как это исправить? Или хотя бы чтобы 10 записей отображались постоянно на одной и той же странице, но сортировались неупорядоченно? Но желательно конечно, чтобы запись могла быть на любой странице один раз. Надеюсь понятно объяснил
CODE (htmlphp):
скопировать код в буфер обмена
  1.  
  2.  
  3. SELECT name, id FROM table LIMIT 20,10 ORDER BY rand()
  4.  
 
 Top
JustUserR
Отправлено: 17 Января, 2011 - 16:16:47
Post Id



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


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


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




ginec пишет:
Если сделать так, то на страницах может попадаться запись с предыдущей страницы. Как это исправить? Или хотя бы чтобы 10 записей отображались постоянно на одной и той же странице, но сортировались неупорядоченно
Для осуществления решения предполагаемой вами задачи по реализации создания выборки основанной на случайной величины с отсутсвием повторяющихся записей - необходимо использования промежуточной VIEW-таблицы для осуществления хранения списка информационных полей полученного в результат проведенной случайной сортировки


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
DeepVarvar Супермодератор
Отправлено: 17 Января, 2011 - 16:45:26
Post Id



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


Покинул форум
Сообщений всего: 10377
Дата рег-ции: Дек. 2008  
Откуда: Альфа Центавра


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




Получить записи в массив и перед циклом вывода этих записей сделать:
array_shuffle($resultarray);
 
 Top
ginec
Отправлено: 17 Января, 2011 - 17:06:10
Post Id



Новичок


Покинул форум
Сообщений всего: 41
Дата рег-ции: Окт. 2010  


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




JustUserR спасибо. а как с нагрузкой дела обстоят?еще погуглю на эту тему

DeepVarvar, спасибо, тоже думал про это. Но в таком случае выходит, что на одной странице будут те же записи, только в разном порядке.

А вообще форум отличный! оперативно, информативно, здорово! Здорово
 
 Top
ginec
Отправлено: 21 Января, 2011 - 23:06:05
Post Id



Новичок


Покинул форум
Сообщений всего: 41
Дата рег-ции: Окт. 2010  


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




Скажите, как сделать рандомное отображение, при пагинации, чтобы не было повторения записей. Временная таблица не подходит((
 
 Top
EuGen Администратор
Отправлено: 24 Января, 2011 - 11:30:58
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




Придется результат выборки сохранять, так как повторный запрос вернет все снова в перемешанном виде. Можно в виде ассоциативного массива ("номер страницы" будет ключем, а массив с данными для этой страницы - значением)


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
movEAX
Отправлено: 24 Января, 2011 - 14:55:51
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 750
Дата рег-ции: Авг. 2009  


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




PHP:
скопировать код в буфер обмена
  1. $mysqli = new mysqli( ... );
  2. $res = $mysqli->query('SELECT COUNT(id) FROM ur_table'); // кэшировать
  3. $maxOffset= array_shift($res->fetch_row());
  4. $mysqli->query('SELECT * FROM ur_table ORDER BY id LIMIT ' . rand(0, $maxOffset-1) . ', 1');


-----
армия.. самое убогое место
 
 Top
ginec
Отправлено: 25 Января, 2011 - 12:04:40
Post Id



Новичок


Покинул форум
Сообщений всего: 41
Дата рег-ции: Окт. 2010  


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




movEAX разве записи не будут повторяться??? Пока сделал с помощью сессии. Работает, но вариант с ней не ахти...
 
 Top
JustUserR
Отправлено: 25 Января, 2011 - 16:53:42
Post Id



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


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


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




ginec пишет:
JustUserR спасибо. а как с нагрузкой дела обстоят?еще погуглю на эту тему
Использование предполагаемого варианта решения не осуществляет существенное увеличение нагрузки на сервер БД по причине использование внутренних native-операций реализация которых является максимально оптимизированной - в частности проявляюшихся накладных расходов является пространство локального диска для осуществления хранения копии таблицы БД с заданным порядком информационных полей


-----
Сделать можно все что угодно - нужно только старание, терпение и хороший поисковик Улыбка
Безлимитный web-хостинг от 15 рублей за 40 МБ дискового пространства - http://ihost[dot]oks71[dot]ru/
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB