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

Э, а как по вашему должен действовать планировщик, если

у него хештаблица не помещается в память? Хештаблицу на диске особого смысла строить нету.

Допустим, вам нужно сджойнить две большие таблицы, данные в память не влазят. Есть два варианта, либо merge join с сортировкой на диске, либо nested loop.

Nested Loop означает, что идет сначала обращение к индексу, а затем обращение к нужной странице heap таблицы - и то и то означает random io как минимум раза 2 на одну строчку, а в случае полного сканирования будет как минимум полное чтение индекса и табличного heap - а это уже как минимум значит прочитать больше данных с диска. Даже у самых лучших ssd от intel по показателю 4k random read пропускная способность на порядок меньше, чем у последовательного чтения с очередью запросов, а у большинства обычных ssd вообще на два порядка разница! В итоге, чтобы прочитать таблицу целиком по индексу, придется прочитать данных с диска больше на размер самого индекса, и при этом еще медленнее как минимум на порядок, по сравнению с последовательным чтением.

1 ответов

3 просмотра

> Хештаблицу на диске особого смысла строить нету. Поясните этот момент, почему вы потеряли смысл сбрасывать на диск ту часть, которая cодержит цепочки некотрого хеш значения.

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

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

Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
34
Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
25
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
19
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
А чем вам питонисты не угодили?😂
.
79
у меня вопрос на счет .global <name> для чего это нужно если я пишу на ассемблере? только для того что бы сделать это видимым для линкера? вот что написано в докумментации GA...
Simple Sorcerer
1
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
У меня вот только только был затык при изучении одной темы. Я настолько привык к джс, что мозг с трудом признал таки, что f и \x -> f x - это равные функции. Потому что в д...
xfides Barabanov
6
Карта сайта