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

Подскажите, как лучше сделать? Есть таблица с большим количеством записей

о файлах. Буду делать агент, который проверяет наличие файла на своем месте и обновлять в таблице поле "дата-время последней проверки". При отсутствии файла будет вносится временная метка в поле "удален". Изредка будет возникать ситуация, когда файл, помеченный ранее как удаленный, снова будет найден на своем месте. Как лучше поступить с точки зрения скорости работы: для всех найденных файлов - обновлять одним запросом оба поля "дата-время последней проверки" и вносить Null в поле "удален" или, принимая во внимание то, что обнаружение на месте ранее удаленного файла - редкое событие предусмотреть отдельный запрос для сброса информации об удалении, а для всех файлов обновлять только одно поле?

24 ответов

23 просмотра

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

Alexander-Morozov Автор вопроса
Ilya Anfimov
Учитывая, что возвращать удалённое планируется ред...

А не получится так, что впустую заменяя Null на Null в 99.999% случаев я потрачу времени на замену двух полей больше чем на одно? (БД - MySQL.)

Alexander Morozov
А не получится так, что впустую заменяя Null на Nu...

Нет, ему всё равно. Точнее, разница в сотни тактов не будет измеримой.

Alexander-Morozov Автор вопроса
Ilya Anfimov
Нет, ему всё равно. Точнее, разница в сотни тактов...

Спасибо! Принимая во внимание то, что первый вариант еще и короче по размеру кода его и выберу.

Alexander Morozov
А не получится так, что впустую заменяя Null на Nu...

Всем классическим СУБД примерно всё равно -- они достают тапл для обновления цэликом, и потом цэликом его записывают. У некоторых есть оптимизацыи чтобы не бродить по индэксам и не трогать их если индэксируемое не сменилось -- но все сравнивают индэксированное значение до и после, им тожэ всё равно -- указано оно или нет.

Ilya Anfimov
Всем классическим СУБД примерно всё равно -- они д...

Пг перестраивать будет. В пг как раз надо учитывать что и как ты апдейтишь.

Ilya Anfimov
Нет.

А с какой версии пг научился не трогать Индексы поля которых не менялись?

alias cd='rm -rf'
Пг перестраивать будет. В пг как раз надо учитыват...

Сейчас pg не перестраивает если ни одно из индэксируемых полей не изменилось и на страницэ есть место для новой записи. И перестраивает если хоть одно изменилось. При этом изменение определяется побайтовым сравнением старого и нового полей тапла.

alias cd='rm -rf'
А с какой версии пг научился не трогать Индексы по...

В районе 12. Лень искать. В 12 оно ужэ было, в 9.6 не было. Читайте про HOT UPDATE.

alias cd='rm -rf'
А с какой версии пг научился не трогать Индексы по...

И да, неважно -- есть там HOT UPDATE или нет. В любом случае -- путь изменений абсолютно одинаков, заменишь ты нормального размера поле на то жэ значение или нет.

С точки зрения скорости это пока рано, предъяви несколько решений, я смогу сказать, что быстрее, а что медленнее

Ilya Anfimov
И да, неважно -- есть там HOT UPDATE или нет. В лю...

А это как то экспереминтально увидеть можно?

Alexander-Morozov Автор вопроса
Ilya Zviagin
С точки зрения скорости это пока рано, предъяви не...

1) update files set checkdate=sysdate(), deletedate=Null where path='Путь к файлу'; 2) update files set checkdate=sysdate() where path='Путь к файлу'; и отдельный блок для выявления восстановленных файлов.

Ilya Anfimov
Что именно из "этого"?

Увидеть хочу что не перестраиваются все Индексы при апдейт поля которое не в индексе.

alias cd='rm -rf'
Увидеть хочу что не перестраиваются все Индексы пр...

Ну, можэшь сформировать HOT UPDATE и посмотреть через pageinspect, что получилось.

alias cd='rm -rf'
О. Точна. Пасиб.

При этом смотреть есть некоторый смысл при открытой транзакцыи -- иначе через небольшое время по идее вакуум вычистит лишнее и из HOT CHAIN и из индэкса, так что отличить одно от другого не получится.

Alexander-Morozov Автор вопроса

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

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

Подскажите, а есть vault lite или ченить такое?) А то нужен вольт для похода в вольт, но весит он ~500 мб) как-то многовато для парочки запросов ))
Alexandr Orloff
17
Всем привет, есть небольшая проблема Есть такой скрипт document.addEventListener('DOMContentLoaded', function () { const sliderTabs = document.querySelectorAll('.s...
A da
8
@go1337 @dblackCat Привет. Все ещё дрочусь с fastpanel. Добавил второй домен который должен смотреть в рут того же сайта, но так как это просто домен, а не сайт, я не могу ему...
Ross 🦴
9
До речі, в ево нема можливості чи якого розширення щоб з адмінки з телефона зайти і терміново щось в верстці поправити?
Женя
7
Ну, так - шо, грамодяне-эрленгяне? Все - готовы подписаться под словами "гуру" на счёт трудности применения POSIX threads и про, конкретно, мьютексы, что "... недопоставишь м...
Wlad
21
кто-нибудь пользуется тайм-трекерами во время работы? так много разных нагуглил, может есть что-то популярное
Lencore
8
Пацаны. Я разрабатываю софт для инвайтинга на телетон, и столкнулся с такой проблемой, в один из чатов не могу приглашать никого, не дает добавлять, в то же время через официа...
Kernel Panic
11
Скажите, а кому нужен Currency как отдельный плагин вместо полноценного ecommerce в OctoberCMS? Кто-то использует его уже или планирует в будущем? Может я что-то не понимаю?
Igor
13
Розмовами про Рево мені нагадали часи, коли шаблони правилися прямо в адмінці. Хто в курсі, чому відійшли від цієї практики, так блейд не працює? Доволі зручно ж було (інколи)
Женя
3
привет, как сбилдить свифт прогу статически? делаю -Xswiftc -static-executable - получаю такую ошибку: /lib/aarch64-linux-gnu/libc.a(pthread_join_common.o)(.note.stapsdt+0x14...
🦊 Fox 🌸 🌸
6
Карта сайта