
问题描述
在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):
xpf.reporting.form crm.lead
注意事项:
- 在视图定义中,使用 inherit_id 属性指定要继承的视图的ID。
- 使用 xpath 表达式定位要插入自定义字段的位置。
- 确保在模块的 __manifest__.py 文件中正确声明模型和视图文件。
总结
理解Odoo的模型继承机制对于避免常见的开发错误至关重要。 当使用 _inherit 继承现有模型时,务必不要定义 _name 属性。 遵循正确的继承方式,可以有效地扩展现有模块的功能,而不会导致数据库表和字段冲突。 通过本文提供的解决方案和示例,你可以轻松解决 "TypeError: Many2many fields ... use the same table and columns" 错误,并构建更加健壮和可维护的Odoo模块。










