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
Форумы портала PHP.SU :: Версия для печати :: Двойной лимит на выборку в MySQL
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » Двойной лимит на выборку в MySQL

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

1. bambr32 - 15 Марта, 2015 - 08:45:01 - перейти к сообщению
Проблема такая: есть таблица, из которой нужно выбрать 10 записей с наивысшим значением колонки CTR, а уже из этих десяти - выбрать три записи случайным образом

Базовый запрос выглядит так:
$qr_result = mysql_query("select * from table ORDER BY CTR Desc LIMIT 10")
or die(mysql_error());
$num_rows = mysql_num_rows( $qr_result );
while($data = mysql_fetch_array($qr_result)) {
///здесь отображаем 3 записи из 10, выбранные случайным образом
}

Как модифицировать данный запрос, чтобы он оставил 3 записи из 10, выбрав их случайным образом?
2. Мелкий - 15 Марта, 2015 - 08:54:21 - перейти к сообщению
CODE (SQL):
скопировать код в буфер обмена
  1. (SELECT * FROM TABLE ORDER BY CTR DESC LIMIT 10) ORDER BY rand() LIMIT 3
3. DeepVarvar - 15 Марта, 2015 - 14:03:14 - перейти к сообщению
Мелкий пишет:
double LIMIT
Don't work with MySQL 5.1
4. Мелкий - 15 Марта, 2015 - 16:22:25 - перейти к сообщению
Мда?
А более длинный вариант работает на 5.1? Я пару недель потушил половину виртуалок и дропнул все инстансы mysql, кроме одного, а тот 5.5 и теперь.мне лениво заниматься некромантией и раскатывать mysql5.1 Ниндзя
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM (SELECT * FROM TABLE ORDER BY CTR DESC LIMIT 10) ORDER BY rand() LIMIT 3
5. bambr32 - 15 Марта, 2015 - 16:36:03 - перейти к сообщению
Огромное спасибо! То, что нужно!
6. DeepVarvar - 15 Марта, 2015 - 18:31:23 - перейти к сообщению
Мелкий пишет:
А более длинный вариант работает на 5.1?
Ну там не сам мускуль виноват, а бизон - парсер запросов.

CODE (SQL):
скопировать код в буфер обмена
  1. SELECT x . *
  2. FROM (
  3.  
  4. SELECT *
  5. FROM tbl
  6. LIMIT 3
  7. )x
  8. LIMIT 2
Отработал, да и короткий тоже. Видимо у меня уже не тот 5.1.ххх, всмысле там еще цихверки есь, и я совсем не помню на какой именно версии оно фейлилось. Обхожу по привычке стороной.

 

Powered by ExBB FM 1.0 RC1