openerp domain 規則
2013-11-28 09:44
357 查看
oe中的domain多用于自定义搜索条件。
domain中的单个条件是一个三个元素组成的元组。第一个是对象的一个column,也就是字段名;第二个是比较运算符``=, !=, >, >=, <, <=, like, ilike, in, not in, child_of, parent_left, parent_right``;第三个就是用来比较的值了。多个条件用“|”(or),“&”(and),“!”(no)逻辑运算符链接。逻辑运算符作为前缀放置于条件前面。“|”与“&”必须两个条件链接,“!”对一个条件取反。默认逻辑运算符为“&”。
举个例子:
['|','|',('group_ids','in',[g.id for g in user.groups_id]), ('user_id', '=', user.id), '&', ('user_id', '=', False), ('group_ids','=',False), '|','|', ('company_id','=',False), ('company_id','child_of',[user.company_id.id]),('company_id.child_ids','child_of',[user.company_id.id])]
这个例子的意思是:
['|',
'|',('group_ids','in',[g.id for g in user.groups_id]), ('user_id', '=', user.id),
'&', ('user_id', '=', False), ('group_ids','=',False),
'|',
'|', ('company_id','=',False), ('company_id','child_of',[user.company_id.id]),
('company_id.child_ids','child_of',[user.company_id.id])]
写个容易看的方式:
(('group_ids','in',[g.id for g in user.groups_id]) or ('user_id', '=', user.id)) or (('user_id', '=', False) and ('group_ids','=',False)) or (('company_id','=',False) or ('company_id','child_of',[user.company_id.id])) or ('company_id.child_ids','child_of',[user.company_id.id])
domain中的单个条件是一个三个元素组成的元组。第一个是对象的一个column,也就是字段名;第二个是比较运算符``=, !=, >, >=, <, <=, like, ilike, in, not in, child_of, parent_left, parent_right``;第三个就是用来比较的值了。多个条件用“|”(or),“&”(and),“!”(no)逻辑运算符链接。逻辑运算符作为前缀放置于条件前面。“|”与“&”必须两个条件链接,“!”对一个条件取反。默认逻辑运算符为“&”。
举个例子:
['|','|',('group_ids','in',[g.id for g in user.groups_id]), ('user_id', '=', user.id), '&', ('user_id', '=', False), ('group_ids','=',False), '|','|', ('company_id','=',False), ('company_id','child_of',[user.company_id.id]),('company_id.child_ids','child_of',[user.company_id.id])]
这个例子的意思是:
['|',
'|',('group_ids','in',[g.id for g in user.groups_id]), ('user_id', '=', user.id),
'&', ('user_id', '=', False), ('group_ids','=',False),
'|',
'|', ('company_id','=',False), ('company_id','child_of',[user.company_id.id]),
('company_id.child_ids','child_of',[user.company_id.id])]
写个容易看的方式:
(('group_ids','in',[g.id for g in user.groups_id]) or ('user_id', '=', user.id)) or (('user_id', '=', False) and ('group_ids','=',False)) or (('company_id','=',False) or ('company_id','child_of',[user.company_id.id])) or ('company_id.child_ids','child_of',[user.company_id.id])
相关文章推荐
- openerp domain 規則
- OpenERP7.0 Domain条件表达式写法小结
- openerp学习笔记 domain 的应用
- OpenERP7.0 Domain条件表达式写法小结
- odoo(Openerp)如何在字段的on_change方法中动态返回domain
- openerp学习笔记 domain 增加扩展支持,例如支持 <field name="domain">[('type','=','get_user_ht_type()')]</field>
- openerp的非数据库表对象
- 用TcpTrace监控OpenERP客户端和服务器之间的通信
- OpenERP资源链接
- Safely Dumping Hashes from Live Domain Controllers
- 什么是领域驱动设计(Domain Driven Design)?
- How to attack a windows domain
- openerp学习笔记 数据合法性约束(对象约束+数据库约束)
- openerp学习笔记 视图继承(tree、form、search)
- 使用NTDSXtract离线抓取Domain Hash
- openerp经典收藏 深入理解对象(转载)
- openerp学习笔记 错误、警告、提示、确认信息显示
- unp #9 (reading notes) (Unix Domain)
- 解决httpd: Could not reliably determine the server's fully qualified domain name
- 关于 unity3d securityexception no valid crossdomain policy available 的错误解决方法