我有两个相关字段,x_nk_categ_id和x_nk_class_desc。由于某种原因,字段" x_nk_class_desc"正在返回空行。我在表mrp_bom中检查过,字段x_nk_categ_id正确填充了categ_id值,但是列x_nk_class_desc为空。
class mrp_bom(osv.osv):
_inherit = 'mrp.bom'
_name = 'mrp.bom'
_columns = {
'x_nk_default_code': fields.related('product_id',
'default_code', type='char', relation='product.product',
string='Part Number', store=True, readonly=True),
'x_nk_categ_id': fields.related('product_id', 'categ_id',
type='many2one', relation='product.product',
string='Product Category', store=True, readonly=True),
'x_nk_class_desc': fields.related('x_nk_categ_id', 'name',
type='char', relation='product.category', string='Class
Description', store=True, readonly=True),
'x_nk_item_desc': fields.related('product_tmpl_id', 'name',
type='char', relation='product.template', string='Item
Description', store=True, readonly=True),
}
这是我的XML代码:
<record id="adamson_mrp_bom_tree_view_2" model="ir.ui.view">
<field name="name">adamson.mrp.bom.tree.view.2</field>
<field name="model">mrp.bom</field>
<field name="type">tree</field>
<field name="inherit_id"
ref="adamson_systems_engineering.adamson_mrp_bom_tree_view" />
<field name="arch" type="xml">
<xpath expr="/tree/field[@name='product_id']" position="replace">
<field name="x_nk_default_code" />
<field name="x_nk_class_desc" />
<field name="x_nk_item_desc" />
</xpath>
</field>
</record>
以下是空类说明在视图中的显示方式:
答案 0 :(得分:2)
我的odoo安装有点不同,但这(适合你的情况)对我有用:
'x_nk_class_desc': fields.related('product_id', 'categ_id', 'name',
type='char', string='Class Description', store=True, readonly=True),
我做的两个改变是:
从this删除relation='product.category'
我得到(可能是错误的)只有在参考链的最后一个词是引用时才有用(这里是一个char字段)
通过此更改(在主版本上),当我更改该记录的产品时,将填充crm.bom记录的Class Description
。
不直接使用x_nk_categ_id
但重复参考链
此更改使其在安装模块时工作正常:所有Class Description
列都已填满。
我想在安装模块时,只使用现有字段来填充相关字段。