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

Прохожу со стажёрами 9 главу Getting Started. - https://www.odoo.com/documentation/16.0/developer/tutorials/getting_started/09_compute_onchange.html По ходу

главы они не добавляют store=True для compute полей. И вот возник вопрос:
лучше по возможности не сохранять compute поля? (не вешать store=True где это возможно)?

16 ответов

41 просмотр

Зависит от того, для чего данное поле используется

Чаще это определяется - нужен ли вам поиск по этому полю или нет. И нужно ли вам это поле доступное в sql

Andro- Автор вопроса
Anton Goroshkin
Чаще это определяется - нужен ли вам поиск по этом...

вот именно на эту мысль меня натолкнуло - если не нужен поиск по полю, можно не вешать store=True). Но я думал плохо "рекомпьютить" поле каждый раз при открытии формы, когда можно сохранить его..

Anton Goroshkin
Чаще это определяется - нужен ли вам поиск по этом...

Это опасный подход имно. По причине, описанной выше. Потому что может поиск и нужен, но поле будет перезаписываться при каждом открытии вью

Andro
вот именно на эту мысль меня натолкнуло - если не ...

В большинстве задач рекомпьютить при открытии формы - не критично - все будет в рамках приятного времени реагирования для человека. А вот когда у вас вид List то будет происходить рекомпьют для всех записей в списке

Ivan
Это опасный подход имно. По причине, описанной выш...

При каждом открытии - это случай, когда поле для поиска не нужно :)))

алгоритм компьют поля может: 1. для того чтобы рассчитать значение - делать кучу обращений к базе, например - посчитать сумму веса товаров в документу, обращаясь к карточке каждого товара в строках документа(фильтрация услуг), считывая его вес базовой единицы, пересчет по коэффициентам в Единицу измерения товара, выбранной в документе и пр. Чем будут напрягать базу. И это будет происходить каждый раз при попытке отобразить это поле. А можно поставить store=True и пересчитываться оно будет только при изменении исходных данных, а при обращении к полю - будет брать готовое значение. Это же оптимальнее? С другой стороны: пример для расчета нужно "выгребать все проводки по определенному счету, с заданными фильтрами и пр". То в этом случае - пересчет всех полей во всех записях - это перебор. Тогда либо - только компьют, либо рисовать промежуточную модель. 2. рассчет может сильно напрягать процессор, при расчете например матриц, и пр. Тем самым расчет может длиться долго. И все это время будет занят один воркер. А можно просто поставить store=True, один раз рассчитать и брать готовое значение. 3. ну и конечно же: если нужно фильтровать, сортировать и выводить значения в отчет, то конечно же - без store=True - не обойтись.

> поле будет перезаписываться при каждом открытии вью Разве?

Eugene
> поле будет перезаписываться при каждом открытии ...

ага а если это компьют поле добавить в лист вью, то компьют будет запускаться для 80-ти записей. и при пролистывании - Next, Next - еще по 80 каждый раз

Eugene
Это точно при store=True?

Нет. Это про False ресь

Eugene
Это точно при store=True?

не. это при store=False т.е. при обычном компьют поле.

Ivan
?

Он поо False

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта