odoo——日历的一对多与多对一
- # model文件
- # -*- coding: utf-8 -*-
- from odoo import api, fields, models
- class TodoTestYear(models.Model):
- _name = 'todo.year'
- _description = 'To-do Test Year'
- _order = 'start_date'
- # 年度名称
- year_name = fields.Char(string='Name', required=True, translate=True)
- # 年度编码
- year_code = fields.Char(string='Code', required=True)
- # 开始时间
- start_date = fields.Date(string='Start_Date', required=True) # 小于结束时间
- # 结束时间
- end_date = fields.Date(string='End_Date', required=True) # 大于开始时间
- quarter_ids = fields.One2many('todo.quarter', inverse_name='year_id', string='Quarter')
- month_ids = fields.One2many('todo.month',inverse_name='year_id', string='Month')
- class TodoTestQuarter(models.Model):
- _name = 'todo.quarter'
- _description = 'To-do Test Quarter'
- # 季度名称
- quarter_name = fields.Char(string='Quarter_Name', required=True)
- # 季度编码
- quarter_code = fields.Char(string='Quarter_Code', required=True)
- # 开始时间
- start_date = fields.Date(string='Start_Date', readonly=True) # 小于结束时间,逐季变大
- # 结束时间
- end_date = fields.Date(string='End_Date', readonly=True) # 大于开始时间, 逐季变大
- year_id = fields.Many2one(comodel_name='todo.year', string='Year')
- class TodoTestMonth(models.Model):
- _name = 'todo.month'
- _description = 'To-do Test Month'
- # 月份名称
- month_name = fields.Char(string='Month_Name', required=True)
- # 月份编码
- month_code = fields.Char(string='Month_Code', required=True)
- # 开始时间
- start_date = fields.Date(string='Start_Date', readonly=True) # 小于结束时间,逐月变大
- # 结束时间
- end_date = fields.Date(string='End_Date', readonly=True) # 大于结束时间,逐月变大
- # 所属季度
- quarter_id = fields.Many2one(comodel_name='todo.quarter', readonly=True, string='Quarter') # 取值同1年度内的季度行表中的季度,格式为季度的 Code,注意行结构不提供链接
- year_id = fields.Many2one(comodel_name='todo.year', string='Year')
- # xml文件
- <?xml version="1.0"?>
- <odoo>
- <act_window id="todo_test_action"
- name="To-do Test"
- res_model="todo.year"
- />
- <!---->
- <menuitem id="todo_test_menu_action"
- name="Todos"
- action="todo_test_action"/>
- <!--form视图-->
- <record id="todo_test_view_form" model="ir.ui.view">
- <field name="name">To-do Test year Form</field>
- <field name="model">todo.year</field>
- <field name="arch" type="xml">
- <form string="To-do Test">
- <header>
- <button name="create_month" type="object" string="Create Month" class="create_month"/>
- </header>
- <sheet>
- <group name="group_top">
- <group name="group_left">
- <field name="year_name"/>
- <field name="year_code"/>
- </group>
- <group name="group_right">
- <field name="start_date"/>
- <field name="end_date"/>
- </group>
- </group>
- <notebook>
- <page string="Quarter">
- <field name="quarter_ids">
- <tree>
- <field name="quarter_name"/>
- <field name="quarter_code"/>
- <field name="start_date"/>
- <field name="end_date"/>
- </tree>
- </field>
- </page>
- <page string="Month">
- <field name="month_ids">
- <tree>
- <field name="month_name"/>
- <field name="month_code"/>
- <field name="start_date"/>
- <field name="end_date"/>
- <field name="quarter_id"/>
- </tree>
- </field>
- </page>
- </notebook>
- </sheet>
- </form>
- </field>
- </record>
- <!--tree视图-->
- <record id="todo_test_view_tree" model="ir.ui.view">
- <field name="name">To-do Test year Tree</field>
- <field name="model">todo.year</field>
- <field name="arch" type="xml">
- <tree>
- <field name="year_name"/>
- <field name="year_code"/>
- <field name="start_date"/>
- <field name="end_date"/>
- </tree>
- </field>
- </record>
- <record id="todo_test_view_search" model="ir.ui.view">
- <field name="name">To-do Test year Search</field>
- <field name="model">todo.year</field>
- <field name="arch" type="xml">
- <search>
- <field name="year_name" string="Year" filter_domain="['|',('year_name','ilike',self),('year_code','ilike',self)]"/>
- </search>
- </field>
- </record>
- </odoo>
odoo——日历的一对多与多对一的更多相关文章
- EF里一对一、一对多、多对多关系的配置和级联删除
本章节开始了解EF的各种关系.如果你对EF里实体间的各种关系还不是很熟悉,可以看看我的思路,能帮你更快的理解. I.实体间一对一的关系 添加一个PersonPhoto类,表示用户照片类 /// < ...
- Django ORM、一对一、一对多、多对多、详解
上篇博客也提到这些知识点,可能大家还是不太清楚,这篇博客为大家详细讲解ORM中的几个知识点 1.1首先我们先看一个小案例: #_*_coding:utf-8_*_ from django.db imp ...
- 2.1、Hibernate多表操作--一对多、多对一、多对多。
一.什么是一对一.一对多.多对一及多对多关系(以简单的学生和老师的关系为例来说): 1.一对一:学生具有学号和姓名(假定没有同名的学生)这两个属性,那么我知道了学生的学号也就能找到对应的学生姓名,如果 ...
- 【Hibernate框架】关联映射(一对多,多对一)
根据我们的总结计划,上篇文章我们总结了有关于一对一映射相关知识,接下来,我们进行下一个阶段,一对多.多对一映射相关知识. 场景设定: 国家规定,一个人只能在一个公司上班,一个公司可以拥有很多员工.我们 ...
- Hibernate一对一、一对多、多对多注解映射配置
一对一: 一对多: 多对多:
- EF里一对一、一对多、多对多关系的配置
EF关系规则 参考文章:http://www.cnblogs.com/feigao/p/4617442.html Entity Framework 实体间的关系,一对一,一对多,多对多,根据方向性来说 ...
- Hibernate中一对多和多对一关系
1.单向多对一和双向多对一的区别? 只需要从一方获取另一方的数据时 就使用单向关联双方都需要获取对方数据时 就使用双向关系 部门--人员 使用人员时如果只需要获取对应部门信息(user.getdept ...
- Django 一对多,多对多关系解析
[转]Django 一对多,多对多关系解析 Django 的 ORM 有多种关系:一对一,多对一,多对多. 各自定义的方式为 : 一对一: OneToOneField ...
- 六 mybatis高级映射(一对一,一对多,多对多)
1 订单商品数据模型 以订单商品数据为模型,来对mybaits高级关系映射进行学习.
随机推荐
- 阿里PB级Kubernetes日志平台建设实践
干货分享 | 阿里PB级Kubernetes日志平台建设实践https://www.infoq.cn/article/HiIxh-8o0Lm4b3DWKvph 日志最主要的采集工具是 Agent,在 ...
- vmware 两删除一清空
快速处理办法: cat /etc/sysconfig/network-scripts/ifcfg-eth0 sed -i '/UUID/d' /etc/sysconfig/network-script ...
- android studio: 9:57 Unsupported Modules Detected: Compilation is not supported for following modules: map, app, ota, MediaEditor, rcLcmSercive, DroneSDK, qrcodelibrary, rcService, speechService. Unfo
Android studio Error “Unsupported Modules Detected: Compilation is not supported for following modul ...
- TensorFlow Object Detection API —— 测试自己的模型
(flappbird) luo@luo-All-Series:~/MyFile/TensorflowProject/Mask_RCNN/mask_rcnn_20190518/Mask_RCNN/mod ...
- nginx在windows系统中如何启动、重启、停止
nginx在windows系统中如何启动.重启.停止 查看nginx的版本号:nginx -v 启动nginx:start nginx 快速停止或关闭nginx:nginx -s stop 正常停 ...
- [Feature] Feature selection
Ref: 1.13. Feature selection Ref: 1.13. 特征选择(Feature selection) 大纲列表 3.1 Filter 3.1.1 方差选择法 3.1.2 相关 ...
- 激活Microsoft Word 2010
先关闭系统的防火墙(像360安全卫士这类软件),再运行“office 2010 正版验证激活工具”,并点击“Install/Uninstall KMService”安装“KMS”服务器(如下图,在弹出 ...
- CDS视图篇 2
核心数据服务 (CDS) 公司希望使用 SAPS/4HANA 核心数据服务 (CDS) 视图技术.需要学习 CDS 视 图的概念和结构以及语法 . ● 核心数据服务是用于业务实体的 SAP 战略建模方 ...
- mysl创建用户+授权+增、删、改查
1.mysql的root用户无法给普通用户授权问题处理 update mysql.user set Grant_priv='Y' where User='root' and Host='%': flu ...
- 《Django企业开发实战 高效Python Web框架指南》胡阳
链接:https://pan.baidu.com/s/1NmN_IT5RvevCMt9bZCW1-g提取码:2ki9