# 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——日历的一对多与多对一的更多相关文章

  1. EF里一对一、一对多、多对多关系的配置和级联删除

    本章节开始了解EF的各种关系.如果你对EF里实体间的各种关系还不是很熟悉,可以看看我的思路,能帮你更快的理解. I.实体间一对一的关系 添加一个PersonPhoto类,表示用户照片类 /// < ...

  2. Django ORM、一对一、一对多、多对多、详解

    上篇博客也提到这些知识点,可能大家还是不太清楚,这篇博客为大家详细讲解ORM中的几个知识点 1.1首先我们先看一个小案例: #_*_coding:utf-8_*_ from django.db imp ...

  3. 2.1、Hibernate多表操作--一对多、多对一、多对多。

    一.什么是一对一.一对多.多对一及多对多关系(以简单的学生和老师的关系为例来说): 1.一对一:学生具有学号和姓名(假定没有同名的学生)这两个属性,那么我知道了学生的学号也就能找到对应的学生姓名,如果 ...

  4. 【Hibernate框架】关联映射(一对多,多对一)

    根据我们的总结计划,上篇文章我们总结了有关于一对一映射相关知识,接下来,我们进行下一个阶段,一对多.多对一映射相关知识. 场景设定: 国家规定,一个人只能在一个公司上班,一个公司可以拥有很多员工.我们 ...

  5. Hibernate一对一、一对多、多对多注解映射配置

    一对一: 一对多: 多对多:

  6. EF里一对一、一对多、多对多关系的配置

    EF关系规则 参考文章:http://www.cnblogs.com/feigao/p/4617442.html Entity Framework 实体间的关系,一对一,一对多,多对多,根据方向性来说 ...

  7. Hibernate中一对多和多对一关系

    1.单向多对一和双向多对一的区别? 只需要从一方获取另一方的数据时 就使用单向关联双方都需要获取对方数据时 就使用双向关系 部门--人员 使用人员时如果只需要获取对应部门信息(user.getdept ...

  8. Django 一对多,多对多关系解析

    [转]Django 一对多,多对多关系解析   Django 的 ORM 有多种关系:一对一,多对一,多对多. 各自定义的方式为 :        一对一: OneToOneField         ...

  9. 六 mybatis高级映射(一对一,一对多,多对多)

    1  订单商品数据模型 以订单商品数据为模型,来对mybaits高级关系映射进行学习.

随机推荐

  1. 使用Python调用Zabbix API

    Zabbix API官方文档: https://www.zabbix.com/documentation/4.0/zh/manual/api 1.向 api_jsonrpc.php 发送HTTP_PO ...

  2. redis5种数据结构讲解及使用场景

    string  list  hash set zset  探究 Redis 4 的 stream 类型 redis提供了5中数据结构,理解每种数据结构的特点对于redis开发运维非常重要.  一.字符 ...

  3. LeetCode31 Next Permutation and LeetCode60 Permutation Sequence

    Implement next permutation, which rearranges numbers into the lexicographically next greater permuta ...

  4. 分布式文件上传 spring boot + fastdfs + dropzone

    1.首先安装fastDFS 参考链接: https://www.funtl.com/zh/spring-cloud-itoken-codeing/%E5%88%86%E5%B8%83%E5%BC%8F ...

  5. Nginx之web服务器

    Nginx的介绍 Nginx是由俄罗斯的Igor Sysoev使用C语言开发的轻量级.高性能.开源.跨平台的Web服务器. Nginx使用基于事件驱动的架构能够并发处理百万级的TCP连接,高模块化的设 ...

  6. 简易的CRM系统案例之Servlet+Jsp+MySQL版本

    数据库配置 datebase.properties driver=com.mysql.jdbc.Driver url=jdbc:mysql://127.0.0.1:3306/infos usernam ...

  7. std::function以及std::bind

    转自:https://blog.csdn.net/shuilan0066/article/details/82788954 示例1 : 普通函数 void gFunc() { cout << ...

  8. Django之model补充:一对多、跨表操作

    表结构概述 model.py : class Something(models.Model): name = models.CharField(max_length=32) class UserTyp ...

  9. shell数组编程

    .数组定义 [chengmo@centos5 ~]$ a=( ) [chengmo@centos5 ~]$ echo $a 一对括号表示是数组,数组元素用“空格”符号分割开. .数组读取与赋值 得到长 ...

  10. 求数值的n次方根

    二分法 float SqrtByBisection(float n) //用二分法 { if(n<0) //小于0的按照你需要的处理 return n; float mid,last; floa ...