Odoo:如何将SQL语句转换为域

人气:431 发布:2022-10-16 标签: python odoo

问题描述

我要将此复合SQL语句放在字段的域中,该如何操作

SELECT * FROM custom_product INNER JOIN custom_branch_line ON custom_product.id = custom_branch_line.product_id INNER JOIN custom_user_line ON custom_branch_line.branch_id = custom_user_line.branch_id where custom_user_line.user_id = %s" % self.env.user.id

推荐答案

我使用以下代码设法做到了这一点

branch_product_ids = fields.Many2one(comodel_name="custom.product", string="Product",
                                          domain="[('branch_line.branch_id.user_lines.user_id','=', user_id)]")

解释如下:

模型"custom.product"有一个one2any字段"BRANCH_LINE"将其连接到模型"custom.Branch ch.line"

模型"custom.ranch.line"具有多个2one字段"Branch_id",该字段将其连接到模型"custom.Branch"

模型"custom.Branch"有一个将其连接到模型"custom.user.line"的一个2any字段"user_lines"

模型"custom.user.line"具有字段user_id

386