172 похожих чатов

Товарищи, допустим, есть некая таблица, в которой среди прочих полей

есть 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?

2 ответов

7 просмотров

Ну несильно оно скажется... Очень несильно.

а не посмотреть ли вам ClickHouse?

Похожие вопросы

Обсуждают сегодня

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
Есть предложения, как подобное можно упростить?
Hemul GM
12
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
У меня вопросик назрел. Почему, создав класс без наследования и реализации деструктора Destroy, деструктор не вызывался при free. Потом указал наследование от tobject и overri...
Сергей Бычков
9
@y0zhig @shizzard А можно я опишу цель и может вообще ерланг мне не подходит. На текущий момент как я понимаю у ерланга есть легковесные потоки и задача выполняется в каком т...
Дмитрий Спиридонов
5
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
just use free version ?? pycharm has a free version
Fan / Ac
9
Карта сайта