
问题描述
在odoo 15中,当尝试继承一个现有模型(例如 crm.lead)并定义一个新的模型名称(_name)时,可能会遇到上述错误。 这通常发生在尝试创建一个新的模型,该模型继承自现有模型,并添加自定义字段时。
错误原因
该错误的核心原因是,在Odoo的标准模型继承中,不应该定义 _name 属性。 _name 属性用于定义一个全新的模型,而不是继承现有模型。 当你尝试使用 _inherit 继承一个模型,并同时定义 _name 时,Odoo会尝试创建一个新的数据库表,并将继承的模型(例如 crm.lead)的字段也添加到该表中。 这会导致 Many2many 字段冲突,因为它们试图使用相同的数据库表和列。
解决方案
解决此问题的关键是移除模型定义中的 _name 属性。 正确的继承方式应该只包含 _inherit 属性,如下所示:
from odoo import models, fields
class XPFReporting(models.Model):
"""
这是一个报表系统,用于从CRM获取数据,并进行过滤和排序
"""
_inherit = 'crm.lead'
custom_field = fields.Char(string='自定义字段')通过移除 _name 属性,你告诉Odoo你想要扩展现有的 crm.lead 模型,而不是创建一个全新的模型。 这样,Odoo会将 custom_field 添加到 crm.lead 模型对应的数据库表中,而不会导致任何冲突。
完整示例
以下是一个完整的示例,展示了如何正确继承 crm.lead 模型并添加自定义字段:
模型定义 (models/xpf_reporting.py):
from odoo import models, fields
class XPFReporting(models.Model):
"""
这是一个报表系统,用于从CRM获取数据,并进行过滤和排序
"""
_inherit = 'crm.lead'
custom_field = fields.Char(string='自定义字段')视图定义 (views/xpf_reporting_views.xml):
<?xml version="1.0" encoding="utf-8"?>
<odoo>
<!-- 扩展 CRM Lead 表单视图 -->
<record id="view_xpf_reporting_form" model="ir.ui.view">
<field name="name">xpf.reporting.form</field>
<field name="model">crm.lead</field>
<field name="inherit_id" ref="crm.crm_lead_view_form"/>
<field name="arch" type="xml">
<xpath expr="//page[@name='lead_details']" position="after">
<page string="XPF Reporting">
<group>
<field name="custom_field"/>
</group>
</page>
</xpath>
</field>
</record>
</odoo>注意事项:
- 在视图定义中,使用 inherit_id 属性指定要继承的视图的ID。
- 使用 xpath 表达式定位要插入自定义字段的位置。
- 确保在模块的 __manifest__.py 文件中正确声明模型和视图文件。
总结
理解Odoo的模型继承机制对于避免常见的开发错误至关重要。 当使用 _inherit 继承现有模型时,务必不要定义 _name 属性。 遵循正确的继承方式,可以有效地扩展现有模块的功能,而不会导致数据库表和字段冲突。 通过本文提供的解决方案和示例,你可以轻松解决 "TypeError: Many2many fields ... use the same table and columns" 错误,并构建更加健壮和可维护的Odoo模块。










