小伙伴们有没有在做 odoo 复杂的domain时,总是写的不对的情况呢,下面让我们彻底了解domain。
Domain 简单的说就是一种条件语句,用来过滤您的数据。
这些条件,通过使用Polish Notation(波兰表达式) 来定义。
波兰表达式一定要了解清楚明白,否则你对 domain也只是初级了解,可百度搜索了解 波兰表达式。
比如:
<u>正 常 表 达 :</u> ((A AND B) OR C ) OR (D AND E)<u>波兰表达式:</u> ['|', '|', '&', A, B, C, '&', D, E]
解释:
从外面的运算符开始,将它移动到最前面
((A AND B) OR C ) <u>OR</u> (D AND E) =>
<u>OR</u> ((A AND B) OR C ) (D AND E)
注意:下划线的为移动的运算符
重复步骤一,直到所有运算符都移动至最左侧
OR ((A AND B) <u>OR</u> C ) (D AND E)
=> OR <u>OR </u>((A AND B) C ) (D AND E)OR OR ((A <u>AND</u> B) C ) (D AND E)
=> OR OR <u>AND</u> ((A B) C ) (D AND E)OR OR AND ((A B) C ) (D <u>AND</u> E)
=> OR OR AND ((A B) C ) <u>AND</u> (D E)
去除所有的括号
注意: 在写xml 的时候,要用转义
判断运算 : ! (否), | (或), & (与)
条件运算: ‘=’, ‘!=’, ‘<=’, ‘<’, ‘>’, ‘>=’, ‘=?’, ‘=like’, ‘=ilike’, ‘like’, ‘not like’, ‘ilike’, ‘not ilike’, ‘in’, ‘not in’, ‘child_of’