есть last_updated_at TIMESTAMP. Допустим, что это поле обновляется всякий раз, как обновляются любые другие данные в строке и таких обновлений может быть от 100 до 500 на всю таблицу в секунду. Задача: необходимо всегда извлекать любую одну любую строку, у которой значение last_updated_at минимально (наболее давно обновленная строка). Что я собираюсь сделать: построить индекс по полю last_updated_at и делать SELECT * FROM my_table ORDER BY last_updated_at ASC LIMIT 1. Но, так как в моей задаче таблица предполагает много обновлений, значение last_updated_at будет постоянно меняться, что приведет к постоянному перестраиванию индекса, и, насколько я понимаю, может сказаться на общей нагрузке на систему. Вопрос: что делать в такой ситуации, когда нужен индекс по полю, которое постоянно меняется, да еще и требуется каждый раз прозводить сортировку для выборок? Есть какой-то более оптимальный вариант для подобного workflow?
Ну несильно оно скажется... Очень несильно.
а не посмотреть ли вам ClickHouse?
Обсуждают сегодня