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

Господа, позвольте задать следующий вопрос: Если в таблицу добавить новый столбец,

и попытаться заполнить его с помощью UPDATE, верно ли я понимаю, что HOT UPDATE не может быть применён (даже при условии что UPDATE не затрагивает столбцы по которым реализованы индексы, а обновляет только вышесозданный столбец), потому что в старых кортежах этого столбца нет, и придётся обязательно переписать версию строки (причём на новую страницу) а значит и обновить индексы?

upd.: тесты показывают что так и есть

2 ответов

12 просмотров

Давайте по порядку. Добавление пустого столбца не приводит к перезаписи строк. Следующий апдейт на не-нулловое значение - приведёт. Но если поле не присутствует в индексах (покрывающие не рассматриваем щас) - ссылка в индексе останется на старую версию строки, в которую добавится указатель на новую, и индексы не перестроятся, для чего и нужен хот

> верно ли я понимаю, что HOT UPDATE не может быть применён Нет, неверно, насколько я помню. > upd.: тесты показывают что так и есть Может, Вы что-то напутали в тестах (или там есть какие-то другие препятствия использованию HOT)? > 2.1. Если делать UPDATE, не дропая индексы, то он происходит мучительно медленно и HOT UPDATE не используется Может, в самих индексах какая-то проблема (там что-то было на эту тему, вроде бы)? > итого получаем seek туда-сюда, что например для HDD совсем не здорово Это, например, работает совсем не так. ;) > Если дропнуть индексы, то UPDATE происходит молниеносно Ну так совсем без индексов всё и должно быть куда быстрее — их обновление далеко не бесплатное. ;(

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

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

А как старый хаскел с новым стыковать ? потому как тут работает https://play.haskell.org/saved/C3xpMzcd, а вот тут https://stepik.org/lesson/7602/step/9?unit=1473 нет ошибка C...
Fedor
131
что насчет пагинга? на осдеве непонятно(
Vi Chapmann 🪙
26
Вопрос я правильно понимаю что в коде newtype ArrowMap k v = ArrowMap { getArrowMap :: k -> Maybe v } getArrowMap есть функция типа k -> Maybe v, если да, то не понимаю задач...
Fedor
64
Народ, кто шарит в расширенных разделах (EBR/EPR) на дисках с разметками MBR? Везде пишут (в вики рус/англ) в частности + другие источники смотрел, что первый сектор расширенн...
Eugene Krasnikov (ᴊɪɴ x)
1
Как Вы считаете нормально ли в двадцатых годах 21 века в ВУЗах Российской Федерации обучать студентов работе с TASM? Не слишком ли это "архаично"? (Если оффтоп или флейм для э...
Spiker01
52
Ребят, что лучше для реверса: гидра или ида?
En Vind Av Sorg
26
Делаю велосипед логгер. К сообщению хочу прикрутить некоторую информацию, типа, кем отправлено, какой уровень, и всякое такое. И тут подумалось мне, почему бы не хранить весь...
Serjone
24
помогите решить вопрос ктото решал это?
Михаил Helper
9
Всем привет! Использую gitlab-ci. Настроил gitlab-agent для деплоя в куб. При деплое проекта в логах такая ошибка: Executing deploy plan failed to watch "ns:my-project/Ingress...
Konstantin Moiseev
4
Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
48
Карта сайта