Skip to Content
Odoo Menú
  • Registra entrada
  • Prova-ho gratis
  • Aplicacions
    Finances
    • Comptabilitat
    • Facturació
    • Despeses
    • Full de càlcul (IA)
    • Documents
    • Signatura
    Vendes
    • CRM
    • Vendes
    • Punt de venda per a botigues
    • Punt de venda per a restaurants
    • Subscripcions
    • Lloguer
    Imatges de llocs web
    • Creació de llocs web
    • Comerç electrònic
    • Blog
    • Fòrum
    • Xat en directe
    • Aprenentatge en línia
    Cadena de subministrament
    • Inventari
    • Fabricació
    • PLM
    • Compres
    • Manteniment
    • Qualitat
    Recursos humans
    • Empleats
    • Reclutament
    • Absències
    • Avaluacions
    • Recomanacions
    • Flota
    Màrqueting
    • Màrqueting Social
    • Màrqueting per correu electrònic
    • Màrqueting per SMS
    • Esdeveniments
    • Automatització del màrqueting
    • Enquestes
    Serveis
    • Projectes
    • Fulls d'hores
    • Servei de camp
    • Suport
    • Planificació
    • Cites
    Productivitat
    • Converses
    • Validacions
    • IoT
    • VoIP
    • Coneixements
    • WhatsApp
    Aplicacions de tercers Odoo Studio Plataforma d'Odoo al núvol
  • Sectors
    Comerç al detall
    • Llibreria
    • Botiga de roba
    • Botiga de mobles
    • Botiga d'ultramarins
    • Ferreteria
    • Botiga de joguines
    Food & Hospitality
    • Bar i pub
    • Restaurant
    • Menjar ràpid
    • Guest House
    • Distribuïdor de begudes
    • Hotel
    Immobiliari
    • Agència immobiliària
    • Estudi d'arquitectura
    • Construcció
    • Gestió immobiliària
    • Jardineria
    • Associació de propietaris de béns immobles
    Consultoria
    • Empresa comptable
    • Partner d'Odoo
    • Agència de màrqueting
    • Bufet d'advocats
    • Captació de talent
    • Auditoria i certificació
    Fabricació
    • Textile
    • Metal
    • Mobles
    • Menjar
    • Brewery
    • Regals corporatius
    Salut i fitness
    • Club d'esport
    • Òptica
    • Centre de fitness
    • Especialistes en benestar
    • Farmàcia
    • Perruqueria
    Trades
    • Servei de manteniment
    • Hardware i suport informàtic
    • Sistemes d'energia solar
    • Shoe Maker
    • Serveis de neteja
    • Instal·lacions HVAC
    Altres
    • Nonprofit Organization
    • Agència del medi ambient
    • Lloguer de panells publicitaris
    • Fotografia
    • Lloguer de bicicletes
    • Distribuïdors de programari
    Browse all Industries
  • Comunitat
    Aprèn
    • Tutorials
    • Documentació
    • Certificacions
    • Formació
    • Blog
    • Pòdcast
    Potenciar l'educació
    • Programa educatiu
    • Scale-Up! El joc empresarial
    • Visita Odoo
    Obtindre el programari
    • Descarregar
    • Comparar edicions
    • Novetats de les versions
    Col·laborar
    • GitHub
    • Fòrum
    • Esdeveniments
    • Traduccions
    • Converteix-te en partner
    • Services for Partners
    • Registra la teva empresa comptable
    Obtindre els serveis
    • Troba un partner
    • Troba un comptable
    • Contacta amb un expert
    • Serveis d'implementació
    • Referències del client
    • Suport
    • Actualitzacions
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Programar una demo
  • Preus
  • Ajuda

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Comptabilitat
  • Inventari
  • PoS
  • Projectes
  • MRP
All apps
You need to be registered to interact with the community.
All Posts People Badges
Etiquetes (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
Etiquetes (View all)
odoo accounting v14 pos v15
About this forum
Ajuda

One2many Field Issue: Child Records Not Automatically Updating When Parent Field Changes

Subscriure's

Get notified when there's activity on this post

This question has been flagged
one2manyv17
3 Respostes
1950 Vistes
Avatar
Thach Nguyen

Hello,


I have an issue with one2many field, please review this example code:


Model:

class ParentModel(models.Model):

    _name = 'parent.model'

    parent_field = fields.Char(compute='_compute_parent_field')

​ children_ids = fields.One2many('child.model', 'parent_id', string='Children')


    @api.depends('children_ids.child_field')

    def _compute_parent_field(self):

        for record in self:

            # Custom logic to compute parent_field based on child_field

            record.parent_field = 'Computed Value' if record.children_ids else 'Default Value'


class ChildModel(models.Model):

    _name = 'child.model'

    parent_id = fields.Many2one('parent.model', string='Parent')

    related_parent_field = fields.Char(related='parent_id.parent_field')


    child_field = fields.Char()



View:

<?xml version="1.0" encoding="utf-8"?>
<odoo>
    <data>
        <record id="parent_model_form" model="ir.ui.view">
            <field name="name">parent_model_form</field>
            <field name="model">parent.model</field>
            <field name="arch" type="xml">
                <form>
                    <sheet>
                        <group>
                            <field name="parent_field"/>
                        </group>
                    <notebook>
                        <page string="Children">
                            <field name="children_ids">
                                <tree>
                                    <field name="child_field"/>
                                    <field name="related_parent_field"/>
                                </tree>
                            </field>
                        </page>
                    </notebook>
                    </sheet>
                </form>
            </field>
        </record>
    </data>
</odoo>


The child_field change value is properly computed, parent_field is updated and displayed in the parent.

The related_parent_field is also updated and displayed for the current child record.


The problem is the other child records are not updated.

When I edit other child records, I see the old value of related_parent_field.


I have to save the parent record to see the changes in other child records.


Hope you can help me with this issue.

Thanks in advance.





Here's a more concrete example that clearly demonstrates the issue:


```python

# Models

class ProductCategory(models.Model):

    _name = 'product.category'

    _description = 'Product Category'

   

    name = fields.Char(string='Category Name', required=True)

    total_products = fields.Integer(string='Total Products', compute='_compute_total_products')

    product_ids = fields.One2many('product.product', 'category_id', string='Products')

   

    @api.depends('product_ids.active')

    def _compute_total_products(self):

        for category in self:

            category.total_products = len(category.product_ids.filtered(lambda p: p.active))



class Product(models.Model):

    _name = 'product.product'

    _description = 'Product'

   

    name = fields.Char(string='Product Name', required=True)

    active = fields.Boolean(string='Active', default=True)

    category_id = fields.Many2one('product.category', string='Category')

    category_total = fields.Integer(related='category_id.total_products', string='Products in Category')

```


```xml

<!-- Product Category Form View -->

<record id="product_category_form_view" model="ir.ui.view">

    <field name="name">product.category.form</field>

    <field name="model">product.category</field>

    <field name="arch" type="xml">

        <form>

            <sheet>

                <group>

                    <field name="name"/>

                    <field name="total_products"/>

                </group>

                <notebook>

                    <page string="Products">

                        <field name="product_ids">

                            <tree>

                                <field name="name"/>

                                <field name="active"/>

                                <field name="category_total"/>

                            </tree>

                        </field>

                    </page>

                </notebook>

            </sheet>

        </form>

    </field>

</record>

```


## Steps to Reproduce the Issue:


1. Create a new Product Category "Electronics"

2. Add three products to this category: "Laptop", "Phone", "Tablet"

3. Notice that `total_products` shows 3 and all products show `category_total = 3`

4. Edit the first product "Laptop" and uncheck the "Active" box

5. Notice that:

   - The `total_products` on the category updates correctly to 2

   - The `category_total` on the "Laptop" product updates correctly to 2

   - But the `category_total` on "Phone" and "Tablet" still shows 3 (incorrect)

6. Only after saving the form, the `category_total` value on all products updates correctly


This example clearly shows how field changes in one record (deactivating a product) correctly trigger computed fields in the parent (category.total_products), but the related fields in sibling records don't refresh automatically without saving.



0
Avatar
Descartar
Avatar
Thach Nguyen
Autor Best Answer

I've added a clearer example to the original post to clarify the issue


I got it working now.


Thank you for your help.


Here are the changes that made it work:


Category model:

@api.depends('product_ids.active')

    def _compute_total_products(self):

        for category in self:

            category.total_products = len(category.product_ids.filtered(lambda p: p.active))

for product in category.product_ids:

​ ​ product.category_total = category.total_products  # Update each product's category_total field


Product Model:


category_total = fields.Integer(store=False, string='Products in Category')


View:


<field name="product_ids" context="{'default_category_total': total_products}">



0
Avatar
Descartar
Avatar
Darshan Kanejiya
Best Answer

Hello Thach,

To ensure child records automatically update when the parent field changes, you can use the @api.depends decorator in the child model. This ensures that changes in the parent model trigger recomputations for the related child records.

Alternatively, you can manually trigger the recomputation using @api.onchange in the parent model, or update the child records using a method call within the parent model.

Both approaches are valid, but using @api.depends in the child model is a cleaner solution if the changes are based on specific computed fields.

0
Avatar
Descartar
Thach Nguyen
Autor

Hello Darshan, thanks for your replay.

Thach Nguyen
Autor

I tried your advice, but I'm still getting the same result.
I've added a clearer example to the original post to clarify the issue. Could you look again?

Avatar
Econ Odoo
Best Answer

Since the parent_field is not stored anyway, maybe it's better to remove the @api.depends. It's calculated everytime it is retrieved whether or not the children are changed.
Another approach is to override the save of the child models to trigger the calcuation of the parent (if you store the calculated value).

0
Avatar
Descartar
Thach Nguyen
Autor

Thanks,
I tried your advices. It still required saving the parent for the changes to apply to all children.
I've added a clearer example to the OP. Could you look again?

Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Registrar-se
Related Posts Respostes Vistes Activitat
Equivalent Attributes in 17 for invisible
one2many v17
Avatar
Avatar
Avatar
2
de març 24
6366
Ya es posible hacer Upgrade de v17 a v17.1 ?
v17
Avatar
Avatar
1
d’oct. 25
1530
How to add a new Many2one field in res.config.settings? Solved
v17
Avatar
Avatar
Avatar
Avatar
4
d’oct. 25
4169
Add field to ALL models in Odoo
v17
Avatar
Avatar
Avatar
2
de set. 25
2709
How to disable Email notification - You have been assigned to Solved
v17
Avatar
Avatar
Avatar
Avatar
4
de set. 25
8263
Community
  • Tutorials
  • Documentació
  • Fòrum
Codi obert
  • Descarregar
  • GitHub
  • Runbot
  • Traduccions
Serveis
  • Allotjament a Odoo.sh
  • Suport
  • Actualització
  • Desenvolupaments personalitzats
  • Educació
  • Troba un comptable
  • Troba un partner
  • Converteix-te en partner
Sobre nosaltres
  • La nostra empresa
  • Actius de marca
  • Contacta amb nosaltres
  • Llocs de treball
  • Esdeveniments
  • Pòdcast
  • Blog
  • Clients
  • Informació legal • Privacitat
  • Seguretat
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo és un conjunt d'aplicacions empresarials de codi obert que cobreix totes les necessitats de la teva empresa: CRM, comerç electrònic, comptabilitat, inventari, punt de venda, gestió de projectes, etc.

La proposta única de valor d'Odoo és ser molt fàcil d'utilitzar i estar totalment integrat, ambdues alhora.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now