首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何从Odoo8中的另一个函数字段中定义one2many字段的域?

在Odoo8中,可以通过在另一个函数字段中定义one2many字段的域。下面是一个示例:

代码语言:txt
复制
from openerp import models, fields, api

class ModelA(models.Model):
    _name = 'model.a'

    name = fields.Char(string='Name')
    model_b_ids = fields.One2many(comodel_name='model.b', inverse_name='model_a_id', string='Model B')

    @api.multi
    def compute_model_b_ids(self):
        for record in self:
            # 根据需要的条件筛选model.b记录
            domain = [('field_name', '=', record.name)]
            model_b_records = self.env['model.b'].search(domain)
            record.model_b_ids = [(6, 0, model_b_records.ids)]

class ModelB(models.Model):
    _name = 'model.b'

    name = fields.Char(string='Name')
    model_a_id = fields.Many2one(comodel_name='model.a', string='Model A')

在上面的示例中,我们有两个模型:ModelA和ModelB。ModelA具有一个名为model_b_ids的one2many字段,它与ModelB相关联。我们在ModelA中定义了一个名为compute_model_b_ids的函数字段,它用于计算model_b_ids字段的域。

compute_model_b_ids函数中,我们可以根据需要的条件筛选ModelB记录,并将结果赋值给model_b_ids字段。在这个例子中,我们使用了一个简单的条件field_name = record.name,你可以根据实际需求进行修改。

请注意,我们使用了[(6, 0, model_b_records.ids)]来更新model_b_ids字段。这是Odoo中用于更新one2many字段的特殊语法。其中,6表示替换所有现有的关联记录,0表示不添加新的关联记录,model_b_records.ids是要关联的记录的ID列表。

这样,当ModelA的name字段发生变化时,compute_model_b_ids函数将自动计算并更新model_b_ids字段的域。

推荐的腾讯云相关产品:腾讯云服务器(https://cloud.tencent.com/product/cvm)

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL 中定义数据字段的类型

MySQL中定义数据字段的类型对你数据库的优化是非常重要的。 MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。...关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。 BIT数据类型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。...该节描述了这些类型如何工作以及如何在查询中使用这些类型。...LONGTEXT 0-4 294 967 295 bytes 极大文本数据 注意:char(n) 和 varchar(n) 中括号中 n 代表字符的个数,并不代表字节个数,比如 CHAR(30)...CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等方面也不同。在存储或检索过程中不进行大小写转换。

2.4K00
  • Django 外键引用另一个表中的多个字段

    在 Django 中,外键(ForeignKey)通常只引用另一张表的一个字段,比如一个主键或一个唯一标识字段。然而,如果我们需要让一个外键引用另一张表中的多个字段,通常有以下几种方法来实现这种关系。...1、问题背景在 Django 中,模型之间的关系通常使用外键(ForeignKey)来建立。外键允许一个模型中的字段引用另一个模型中的主键。然而,有时我们需要在一个模型中引用另一个模型中的多个字段。...2、解决方案为了在 sales_process 表中引用 product_models 表中的多个字段,我们可以使用复合主键(Composite Key)的方式。复合主键是指由多个字段组成的主键。...在 Django 中,我们可以使用 MultipleFieldPrimaryKeys 选项来定义复合主键。...以下是如何在 Django 中使用复合主键来实现外键引用另一个表中的多个字段:在 product_models 模型中,添加一个 id 字段作为主键:class product_models(models.Model

    10510

    MySQL中 如何查询表名中包含某字段的表

    information_schema.tables 指数据库中的表(information_schema.columns 指列) table_schema 指数据库的名称 table_type 指是表的类型...(base table 指基本表,不包含系统表) table_name 指具体的表名 如查询work_ad数据库中是否存在包含”user”关键字的数据表 select table_name from...如何查询表名中包含某字段的表 select * from systables where tabname like 'saa%' 此法只对Informix数据库有用 查询指定数据库中指定表的所有字段名column_name...table_schema from information_schema.tables where table_schema = ‘test’ group by table_schema; mysql中查询到包含该字段的所有表名...SELECT TABLE_NAME FROM information_schema.COLUMNS WHERE COLUMN_NAME='字段名' 如:查询包含status 字段的数据表名 select

    12.7K40

    从 VFP 的角度看 .NET 类中的属性和字段

    大多数 foxer 其实对 VFP 中的“属性”是没有认真考虑过的。然而,在使用 X#(XSharp) 时,不可避免的的在类定义中需要了解它的属性和字段到底是什么意思。...对于合格的 VFP 程序员,在制作自定义类时,通常情况下,会有选择的对一些自定义属性赋予适当的 Access 和 Assign 方法(事实上,针对类固有的属性,也是可以定义的)。...这些操作对于合格的 VFP 程序员来说,轻车熟路。 如果你对我上述的描述了然于胸,那么,对于 X# 中的所谓属性和字段的理解,事实上不应该有难度。...X# 中的所谓属性和字段,依据在 .NET 中的定义,它们有一个很重要的区别,也就是属性可以包含逻辑,而字段是直接存取的。...因此,X# 中的属性,完全可以认为在概念上等同于 VFP 属性;而字段,则可以认为是不具有 Access 和 Assign 方法并且可见性被标识为非 Public 的属性。

    6110

    Java开发中如何自动填充SQL语句中的公共字段

    MetaObjectHandler {     @Override     public void insertFill(MetaObject metaObject) {         // 声明自动填充字段的逻辑...把公共审计字段放进去并声明对应的填充策略: public abstract class BaseEntity的字段。...总结 今天我们 SQL 审计中的一些公共字段的自动填充的常用方案进行了一些介绍,特别对Mybatis Plus提供的功能进行了介绍相信能够帮助你简化一些样板代码的编写。...如果设计的更加精细化的话,会通过镜像或探针的方式采集所有数据库的访问流量,并基于 SQL 语法、语义的解析技术,记录下数据库的所有访问和操作行为。有空可以从网上获取相关的资料进行了解。今天就到这里。

    2.1K10

    【详解】MySQL将一个表的字段更新到另一个表中

    MySQL将一个表的字段更新到另一个表中在数据库管理中,经常需要将一个表中的数据更新到另一个表中。这种操作常见于数据迁移、数据同步等场景。本文将详细介绍如何在MySQL中实现这一功能。1....当需要将一个表的字段更新到另一个表时,可以使用 ​​JOIN​​ 来连接两个表,并进行更新操作。...,我们了解了如何在 MySQL 中将一个表的字段更新到另一个表中。...在实际应用中,需要注意数据的一致性、性能和事务处理,以确保操作的安全性和可靠性。我们经常需要从一个表中提取数据并更新到另一个表中。这种操作通常用于数据同步、数据迁移或数据汇总等场景。...总结通过上述方法,你可以有效地将一个表中的数据更新到另一个表中。这种方法不仅适用于简单的数据更新,还可以扩展到更复杂的数据处理场景。希望这些信息对你有所帮助!

    7100

    mysql sum函数中对两字段做运算时有null时的情况

    背景 在针对一些数据进行统计汇总的时候,有时会对表中的某些字段进行逻辑运算,如加减乘除,如果要求和的话还可能会用到sum函数,如果两者结合起来应该怎么处理,如果参与运算的字段中出现null值的时候会出现一些什么情况...InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci 数据如下 如上表所示,用户信息表中有账户总金额和冻结金额字段...根据表中的数据,我们知道统计后正确的结果应该是 (2000 - 50) + (1500 - 100) + (500 - 50) + 1000 = 4800 但如果我们这么写,那么得到的结果是错误的。...1000而是null,因为null与任何值比较和运算的结果都是null,所以我们应该针对null做特殊处理。...需要主要这样写也是没有用的,因为里面1000-null,仍然是一个错误的结果 select ifnull(sum(total_amount - freeze_amount),0) from user

    1K10

    如何处理数据库表字段值中的特殊字符?

    现网业务运行过程中,可能会遇到数据库表字段值包含特殊字符的场景,此场景虽然不常见,但只要一出现,其影响却往往是致命的,且排查难度较高,非常有必要了解一下。...表字段值中的特殊字符可以分为两类:可见字符、不可见字符。...可见字符处理 业务的原始数据一般是文本文件,因此,数据插入数据库表时需要按照分隔符进行分割,字段值中包含约定的分隔符、文本识别符都属于特殊字符。...,对于不可见字符例如:换行符LF、回车键CR,又该如何处理呢?...UPDATE `WORKORDER` SET WORKID = REPLACE(REPLACE(WORKID, CHAR(10),''), CHAR(13),''); -- 这里使用了函数的嵌套

    4.8K20

    ​一日一技:如何替换URL中的query字段?

    每次请求的时候返回下一页的参数after。当要访问下一页的时候,用这个参数替换当前url中的after=后面的参数。 这样一来,替换url中的参数就并不是一件简单的事情了。...ParseResult 对象的.query 属性,是一个字符串,也就是网址中,问号后面的内容,格式如下: parse_qs与urlencode也是一对相反函数。...其中前者把 .query输出的字符串转成字典,而后者把字段转成.query形式的字符串: 当使用parse_qs把 query转成字典以后,就可以修改参数的值,然后再重新转回去。...由于ParseResult对象的.query属性是只读属性,不能覆盖,因此我们需要调用一个内部方法._replace把新的.query字段替换上去,生成新的 ParseResult对象。...以上,就是今天我们介绍的,如何使用urllib自带的函数替换网址中的字段。 END

    1.8K20
    领券