У меня очень большая (80 + миллионная строка) де-нормированная таблица MySQL. Упрощенная схема выглядит следующим образом:
+-----------+-------------+--------------+--------------+ | ID | PARAM1 | PARAM2 | PARAM3 | +-----------+-------------+--------------+--------------+ | 1 | .04 | .87 | .78 | +-----------+-------------+--------------+--------------+ | 2 | .12 | .02 | .76 | +-----------+-------------+--------------+--------------+ | 3 | .24 | .92 | .23 | +-----------+-------------+--------------+--------------+ | 4 | .65 | .12 | .01 | +-----------+-------------+--------------+--------------+ | 5 | .98 | .45 | .65 | +-----------+-------------+--------------+--------------+
Я пытаюсь выяснить, есть ли способ оптимизировать запрос, в котором я применяю вес к каждому столбцу PARAM (где вес находится между 0 и 1), а затем усредняет их для вычисления вычисленного значения SCORE. Затем я хочу ЗАКАЗАТЬ, что вычисленный столбец SCORE.
Например, если предположить, что взвешивание для PARAM1 равно .5, взвешивание для PARAM2 равно .23, а взвешивание для PARAM3 - 0,76, вы получите нечто похожее на:
SELECT ID, ((PARAM1 * .5) + (PARAM2 * .23) + (PARAM3 * .76)) / 3 AS SCORE
ORDER BY SCORE DESC LIMIT 10
При некотором правильном индексировании это быстро для базовых запросов, но я не могу найти хороший способ ускорить вышеуказанный запрос на такой большой таблице.
Подробности:
- Каждое значение PARAM находится между 0 и 1
- Каждый вес, применяемый к PARAMS, составляет от 0 до 1 с
- EDIT -
Далее следует упрощенная версия проблемы.
Это выполняется в течение разумного промежутка времени:
SELECT value1, value2
FROM sometable
WHERE id = 1
ORDER BY value2
Это не выполняется в течение разумного промежутка времени:
SELECT value1, (value2 * an_arbitrary_float) as value3
FROM sometable
WHERE id = 1
ORDER BY value3
Используя приведенный выше пример, есть ли какое-либо решение, которое позволяет мне выполнить ORDER BY с вычисленным значением вычисления3 раньше времени?