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高级关系映射进行学习.
随机推荐
- 关于$internalField边界条件【翻译】
翻译自:CFD-online 帖子地址:http://www.cfd-online.com/Forums/openfoam-pre-processing/122386-about-internalfi ...
- pc电源cpu插座和显卡插座
cpu插座是8口的,一般4+4 显卡插座是6口的,也有8口的用6+2 6+2的中2有一个小边,组合成8口也不能插入cpu插座.
- 总结js常用的dom操作(js的dom操作API)
转载:https://www.haorooms.com/post/js_dom_api 前言 很多同学用惯了jquery操作dom,让他们用js操作的时候,常常力不从心,本文总结了常用的js的dom操 ...
- OpenTK学习笔记(3)-你好!窗体!
参考:http://dreamstatecoding.blogspot.com/2017/01/opengl-4-with-opentk-in-c-part-1.html http://www.cnb ...
- python小白之数组索引
索引 numpy中的数组索引形式和Python是一致的.如: np.arange(10) print x[2] #单个元素,从前往后正向索引.注意下标是从0开始的. print x[-2] #从后 ...
- sql日期比较
sql 中 datetime日期类型字段比较 mysql 可以直接用大于号,也可以用 between and SELECT * FROM staff WHERE UPDATE_DATE >= ...
- mysql插入数据时 insert IGNORE、ON DUPLICATE KEY UPDATE、replace into
转: mysql insert时几个操作DELAYED .IGNORE.ON DUPLICATE KEY UPDATE的区别 博客分类: mysql基础应用 mysql insert时几个操作DE ...
- BIM IFC算量
1.基础工程:挖槽.垫层.基础底板.基础墙.地圈梁.暖气沟.回填土等:2.主体工程:梁.板.柱.墙等:3.屋顶工程:挑檐.女儿墙.保温.防水.压顶等:4.装修工程:外墙抹灰.墙裙.门窗套.内墙抹灰.粉 ...
- osg 在场景中绘制坐标轴(xyz)
//x y z font_size osg::Geode* makeCoordinate(float a_x,float a_y,float a_z,float font_size) { osg::r ...
- office激活方式,超简单
只需要安装个小小的程序,亲测安全可靠 详情点击下方链接 https://blog.csdn.net/weixin_40941966/article/details/80872533