型号属性

在/模型添加activity.py文件

class ActivityEvent(models.Model):
_name = 'activity.event'
_inherit = 'event.event'
_rec_name = 'test_field' # 字段
test_field = fields.Char(string="字段名称") # 多对多的关联表
employee_ids = fields.Many2many('files.employee', 'activity_event_files_employee_rel', string='与会员工')
event_type_id = fields.Many2one(
'activity.type', string='Category',
readonly=False, states={'done': [('readonly', True)]},
oldname='type')
  • model属性详解::类型

  • _name唯一标识,类非继承父类时必须指定。

  • _rec_name:数据显示名称,如设置则返回其指定的字段值,不设置默认显示字段为name的字段值,如无名字段则显示“模块名,ID”;详见BaseModel.name_get方法。

  • _log_access:是否自动增加日志字段(create_uid,create_date,write_uid,write_date)默认为真。

  • _auto:是否创建数据库对象默认为真,详见BaseModel._auto_init方法。

  • _table:数据库对象名称缺。省时数据库对象名称与_name指定值相同(.替换为下划线)

  • _sequence。:数据库id字段的序列。默认自动创建序列。

  • _order:数据显示排序。所指定值为模型字段,按指定字段和方式排序结果集。

      例:_order =“create_date desc”:根据创建时间降序排列。可指定多个字段。
    不指定desc默认升序排列;不指定_order默认id升序排列。
  • _constraints:自定义约束条件模型创建/编辑数据时触发,约束未通过弹出错误提示,拒绝创建/编辑。

      格式:: _constraints = [(method, 'error message', [field1, ...]), ...]
    method检查方法。返回True | False
    error message:不符合检查条件时(方法返回False)弹出的错误信息
    [field1, ...]:字段名列表,这些字段的值会出现在错误消息中。 _sql_constraints:数据库约束。 例:_sql_constraints = [ ('number_uniq', 'unique(number, code)', 'error message') ]
    会在数据库添加约束:
    CONSTRAINT number_uniq UNIQUE(number, code)
  • _inherit。:单一继承值为所继承父类_name标识如子类不定义_name属性,则在父类中增加该子类下的字段或方法,不创建新对象;如子类定义_name属性,则创建新对象,新对象拥有父类所有的字段或方法,父类不受影响。

      格式:_inherit = '父类 _name'
  • _inherits:多重继承子类通过关联字段与父类关联,子类不拥有父类的字段或方法,但是可以直接操作父类的字段或方法。

      格式:_inherits = {'父类 _name': '关联字段'}

字段属性

基础类型

  • Char:字符型,使用尺寸参数定义字符串长度。

  • Text:文本型,无长度限制。

  • Boolean:布尔型(真,假)

  • Interger:整型

  • Float:浮点型,使用数字参数定义整数部分和小数部分位数如。digits=(10,6)

  • Datetime:日期时间型

  • Date:日期型

  • Binary:二进制型

  • selection:下拉框字段。

      例:state = fields.Selection([('draft', 'Draft'),('confirm', 'Confirmed'),('cancel', 'Cancelled')], string='Status')
  • Html:可设置字体格式,样式,可添加图片.

关系类型

1. One2many:一对多关系。

  • 定义:otm = fields.One2many("关联对象 _name", "关联字段",string="字段显示名",...)

  • 例:analytic_line_ids = fields.One2many('account.analytic.line', 'move_id', string='Analytic lines')"

2. Many2one

  • 定义:mto = fields.Many2one("关联对象 _name", string="字段显示名",...)

  • 可选参数:ondelete,可选值为'级联'和'空',缺省为空表示一个端删除时多端是否级联删除。

3. Many2many

  • 定义:mtm = fields.Many2many("关联对象 _name", "关联表/中间表","关联字段1","关联字段2",string="字段显示名",...)

    其中,关联字段,关联表/中间表可不填,中间表缺省为:表1_表2_rel

  • 例:partner_id= fields.Many2many("res.partner", string="字段显示名",...)"

复杂类型

参数

  • readonly: 是否只读,缺省值False。

  • required: 必填填,缺省值Falsse。

  • string: 字段显示名,任意字符串。

  • default: 字段默认值

  • domain: 域条件,缺省值[]。在关系型字段中,domain用于过滤关联表中数据。

  • help: 字段描述,鼠标滑过时提示。

  • store: 是否存储于数据库。结合计算和相关使用。

      例:sale_order = fields.One2many("sale.order", "contract_id",string="销售订单", domain=[('state','=','sale')])
  • compute:字段值由函数计算,该字段可不储存于数据库。

      例:amount = fields.Float(string="金额总计", compute=‘_compute_amount’,store=True)
    _compute_amount为计算函数。
  • related:字段值引用关联表中某字段。

      以下代码表示:company_id引用hr.payroll.advice中company_id
    
      advice_id = fields.Many2one('hr.payroll.advice', string='Bank Advice')
    company_id = fields.Many2one('res.company', related='advice_id.company_id', string='Company', store=True)

odoo 模型与ORM的更多相关文章

  1. odoo12从零开始:三、2)odoo模型层

    前言 上一篇文章(创建你的第一个应用模块(module))已经大致描述了odoo的模型层(model)和视图层(view),这一篇文章,我们将系统地介绍有关于model的知识,其中包括: 1.模型的类 ...

  2. python 全栈开发,Day70(模板自定义标签和过滤器,模板继承 (extend),Django的模型层-ORM简介)

    昨日内容回顾 视图函数: request对象 request.path 请求路径 request.GET GET请求数据 QueryDict {} request.POST POST请求数据 Quer ...

  3. Django基础(2)--模板自定义标签和过滤器,模板继承 (extend),Django的模型层-ORM简介

    没整理完 昨日回顾: 视图函数: request对象 request.path 请求路径 request.GET GET请求数据 QueryDict {} request.POST POST请求数据 ...

  4. Odoo中的ORM API(模型数据增删改查)

    转载请注明原文地址:https://www.cnblogs.com/ygj0930/p/10826214.html 一:增 1:create():返回新创建的记录对象 self.create({'na ...

  5. (03)odoo模型/记录集/公用操作

    -----------------更新时间11:17 2016-09-18 星期日11:00 2016-03-13 星期日09:10 2016-03-03 星期四11:46 2016-02-25 星期 ...

  6. odoo 的一些orm 操作

    1.基础文件及目录结构 在认识odoo ORM框架前,先介绍一下odoo中模块目录结构.     data:存放模块预制数据 i18n:存放国际化文件 models:存放模型等py代码 securit ...

  7. odoo中的ORM操作

    ORM方法简介 OpenERP的关键组件, ORM是一个完整的对象关系映射层,是开发人员不必编写基本的SQL管道. 业务对象被声明继承字models.Models的python类. 这让业务对象在OR ...

  8. odoo 模型继承

    在odoo中有两种模型的继承机制(传统方式和委托继承方式) 重点:在__manifest__.py中找到depends,加上要继承的模块 'depends': ['account'] 注意继承的模型所 ...

  9. (17)模型层 -ORM之msql 单表的增、删、改、查 及其他操作

    单表操作-增.删.改.查 ret=models.User.objects.filter(id=1)  #这里的结果是一个queryset对象 ret=modles.User.Objects.filte ...

随机推荐

  1. [csp-201509-3]模板生成系统

    #include<bits/stdc++.h> using namespace std; ; string a[N],b[N],c[N]; int main() { //freopen(& ...

  2. PartyPlay发布版

    发布版本在beta版本的基础之上修改了pose王中的显示函数部分,使其可以正常的多次显示不同图片,不会出现卡在一张图片的问题上. 因此总的发布版本内容: 1.谁是卧底: 点击进入谁是卧底,进入游戏前的 ...

  3. 【转】C#中Graphics的画图代码

    C#中Graphics的画图代码[转] 架上图片了你就可以在画板上涂改了啊 我要写多几个字上去string str = "Baidu"; //写什么字?Font font = Fo ...

  4. SpringBoot与异步任务、定时任务、邮件任务

    异步任务 在需要开启异步的服务加上注解:@Async @Service public class AsyncService { //告诉SpringBoot这是一个异步任务,SpringBoot会自动 ...

  5. 训练赛第一场D题

    解题报告:一开始不知道ATA的意思,后来才知道原来是转置矩阵乘以原来的矩阵.这题说起来比较麻烦就不说了,直接上代码: #include<cstdio> #include<cstrin ...

  6. vue_router 动态路由

    配置子路由: 路由的视图都需要使用view-router 子路由也可以嵌套路由使用: children来做嵌套如上图 使用location.页面name就可以做页面跳转 mounted:挂载,延迟跳转 ...

  7. 在Django中Session的那点事!

    1.session是什么 首先引入度娘的解释:Session:在计算机中,尤其是在网络应用中,称为“会话控制”.Session 对象存储特定用户会话所需的属性及配置信息.这样,当用户在应用程序的 We ...

  8. 2016.5.19——vector型的输入输出

    vector型的输入输出 在上节2015.5.18——leetcode:Majority Element中纠结vector的动态输入输出问题,但是发现vector传参型的不可以动态输入输出,但是vec ...

  9. CentOS7最小化安装之后无法联网以及无法使用ifconfig以及无法使用yum安装软件

    无法联网解决办法,CentOS-7默认网卡未激活,进入BOOS设置修改,或者直接修改配置文件,然后重启服务 1 修改网卡配置文件: 激活: 2 重启服务即可: service network rest ...

  10. python网络编程--进程线程

    一:什么是进程 一个程序执行时的实例被称为一个进程. 每个进程都提供执行程序所需的资源.一个进程有一个虚拟地址空间.可执行代码.对系统对象的开放句柄.一个安全上下文.一个独特的进程标识符.环境变量.一 ...