Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   Вебмастеру (http://forum.oszone.net/forumdisplay.php?f=22)
-   -   Выбор данных из mysql с приоритетом ? (http://forum.oszone.net/showthread.php?t=54806)

m2001 06-10-2005 13:12 362015

Выбор данных из mysql с приоритетом ?
 
Вопрос:
Есть таблица в mysql, с которой выбирается строка следующим образом:
SELECT * FROM table WHERE X ORDER BY RAND() LIMIT 1

в таком случае случайным образом выбирается строка из таблицы. А можно ли как-нибудь сделать, чтоб у некоторых строк был приоритет выборки выше, т.е. они чаще выбирались?

Vlad Drakula 06-10-2005 15:14 362063

m2001
SELECT *, pr=pr*RAND() FROM table WHERE X ORDER BY pr LIMIT 1


m2001 06-10-2005 18:09 362114

Vlad Drakula
Если pr - это ячейка таблицы со значением приоритета, то при такой схеме у меня оно равно нулю.

Такой запрос не совсем подходит.

Мне надо реализовать следуещее:
Предположим, в таблице есть три строки. У каждой задан приоритет, у первой -5, у второй - 3, у третей - 2.
Из php-скрипта мы посылаем запрос в базу. И надо, чтоб при 10 последовательных запусков скрипта информация из первой строки выбиралась 5 раз, из второй 3 раза и из третьей 2 раза.

mar 06-10-2005 19:05 362132

m2001
тогда надо после выбора update-ить таблицу (или сопряженную таблицу), где крутить счетчики. Ну и выборку осуществлять с учетом счетчиков. К сожалению неверхняя ветка mysql не знает транзакций (да и в верхней они вроде как не до конца нормально сделаны), а так в транзакциях и хранимых процедурах, или в триггерах (которых и в верхней ветке, вроде нет?) таким фокусам самое место.

m2001 07-10-2005 10:50 362288

эх... mysql не оправдало возложенных на неё прогнозов... и ORDER BY RAND() работает криво.

Может кто подскажет как оптимальнее сделать таблицу с баннерами и как организовать случайный выбор баннера с приоритетом ?

Vlad Drakula 07-10-2005 11:44 362316

m2001
я же вроде приводил тебе пример выборки?

m2001 10-10-2005 13:37 363032

Vlad Drakula
я написал что RAND() криво работает... придется самому писать эти счетчики.

Vlad Drakula 10-10-2005 13:50 363037

m2001
в принцепе это не сложно, но нужно не плохо продумать все чтобы достичь нужного перфоманса!

Igor_I 10-10-2005 20:18 363111

m2001
Цитата:

ORDER BY RAND() работает криво.
В смысле криво? (малость догадываюсь) :)
А как выпадают циферки на кубике, тоже криво? :)
Я думаю надо сделать еще одну табличку. В которую заносить кол-во показов. 5 показов - обнуление, 3 - обн..


Время: 00:15.

Время: 00:15.
© OSzone.net 2001-