# 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. Mixed Content: The page at ‘https://XXX’ was loaded over HTTPS, but requested an insecure........

    iframe引入视频的文件的时候报这个错 其实只要改成 加上一个s就好了  ...

  2. Flutter移动电商实战 --(53)购物车_商品列表UI框架布局

    cart_page.dart 清空原来写的持久化的代码; 添加对应的引用,stless生成一个静态的类.建议始终静态的类,防止重复渲染 纠正个错误,上图的CartPage单词拼错了,这里改过来防止后面 ...

  3. Oracle的大表,小表与全表扫描

    大小表区分按照数据量的大小区分: 通常对于小表,Oracle建议通过全表扫描进行数据访问,对于大表则应该通过索引以加快数据查询,当然如果查询要求返回表中大部分或者全部数据,那么全表扫描可能仍然是最好的 ...

  4. Packetbeat简介

    Packetbeat简介 抓包示例 下载packetbeat 抓取elasticsearch的包 ①启动elasticsearch 启动packetbeat 配置es.yml ############ ...

  5. 【转载】 AutoML总结

    原文地址: https://jinxin0924.github.io/2017/12/21/AutoML%E6%80%BB%E7%BB%93/ Posted by JxKing on December ...

  6. NULL和nullptr

    NULL就是0 nullptr是空指针[c++11]

  7. 《海会圣贤》高清字幕版(由香港佛陀教育协会发布DVD恭敬转成)

    常念阿彌陀佛 2015-09-22 视频(建议WIFI下收看)时长72分钟 https://v.qq.com/x/page/f0166amk57h.html 香港佛陀教育协会发布DVD   DVD+高 ...

  8. jQuery跨域调用WebService

    jQuery跨域调用WebService举例html: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&qu ...

  9. 无缝轮播 css3

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. 手写C++代码实现POST传输数据

    char *pHttpPost = "POST %s HTTP/1.1\r\n" "Host: %s:%d\r\n" "Content-Type: a ...