нем есть поле many2many
пользователи поработали некоторое время и решили, что теперь поле должно быть many2one
допустим, что мы будем оставлять только одно значение (первое в списке) в этом поле
как правильно сделать правки такого модуля?
это должна быть какая-то миграция через доп поля или как это делать
или где почитать такую инфу?
можно без миграции в два єтапа: 1. сначала добавляем поле в код. 1.1. в коде все механизмы со старого поля переписываем на работу, на новое поле. В идеале, делаем переключатель через ir.config 1.2. устанавливаем на сервер. после апдейта модуля, заливаем в него данные(разные есть способы) 1.3. проверяем что механизмы теперь работают через новое поле. Для этого меняем значение в старом поле и проверяем, что алгоритмы на него не реагируют. 2. Далее все просто: удаляем из кода старое поле, деплой, апдейт, фенито ля комедия.
по идеи можно прям тип поля поменять с many2many на many2one, написать миграционный скрипт post-update в котором обращаетесь в базу через SQL в промежуточную таблицу (которая используется для связи m2m) и через поля отношения вытаскиваете данные и берете одну найденную запись (как брать тут уже зависит от задачи: первую попавшую, или самую свежую )
а эта тбалица не удаляется при смене типа поля?
В разных версиях оду по разному. В последних постепенно приходят к тому, чтобы как можно чище все чистить за orm.
Обсуждают сегодня