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 :: Двойной лимит на выборку в MySQL

 PHP.SU

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


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

> Без описания
bambr32
Отправлено: 15 Марта, 2015 - 08:45:01
Post Id


Новичок


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


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




Проблема такая: есть таблица, из которой нужно выбрать 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, выбрав их случайным образом?
 
 Top
Мелкий Супермодератор
Отправлено: 15 Марта, 2015 - 08:54:21
Post Id



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


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


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




CODE (SQL):
скопировать код в буфер обмена
  1. (SELECT * FROM TABLE ORDER BY CTR DESC LIMIT 10) ORDER BY rand() LIMIT 3


-----
PostgreSQL DBA
 
 Top
DeepVarvar Супермодератор
Отправлено: 15 Марта, 2015 - 14:03:14
Post Id



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


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


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




Мелкий пишет:
double LIMIT
Don't work with MySQL 5.1
 
 Top
Мелкий Супермодератор
Отправлено: 15 Марта, 2015 - 16:22:25
Post Id



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


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


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




Мда?
А более длинный вариант работает на 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


-----
PostgreSQL DBA
 
 Top
bambr32
Отправлено: 15 Марта, 2015 - 16:36:03
Post Id


Новичок


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


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




Огромное спасибо! То, что нужно!
 
 Top
DeepVarvar Супермодератор
Отправлено: 15 Марта, 2015 - 18:31:23
Post Id



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


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


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




Мелкий пишет:
А более длинный вариант работает на 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.ххх, всмысле там еще цихверки есь, и я совсем не помню на какой именно версии оно фейлилось. Обхожу по привычке стороной.
 
 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