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

Odoo: how to turn a sql statement into a domain(Odoo:如何将SQL语句转换为域)

本文介绍了Odoo:如何将SQL语句转换为域的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我要将此复合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

这篇关于Odoo:如何将SQL语句转换为域的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:Odoo:如何将SQL语句转换为域

基础教程推荐