odoo 开发入门教程系列-约束(Constraints)

约束(Constraints)

上一章介绍了向模型中添加一些业务逻辑的能力。我们现在可以将按钮链接到业务代码,但如何防止用户输入错误的数据?例如,在我们的房地产模块中,没有什么可以阻止用户设置负预期价格。

odoo提供了两种设置自动验证恒定式的方法:Python约束 and SQL约束

SQL

参考:与此主题相关的文档可以查看 ModelsPostgreSQL文档

我们通过模型属性_sql_constraints来定义SQL约束,该属性被赋值为一个包含三元组(name, sql_definition, message)的列表,其中name为一个合法的SQL约束名称, sql_definition表约束表达式,message为错误消息。

一个简单的示例

class AccountAnalyticDistribution(models.Model):
    _name = 'account.analytic.distribution'
    _description = 'Analytic Account Distribution'
    _rec_name = 'account_id'

    account_id = fields.Many2one('account.analytic.account', string='Analytic Account', required=True)
    percentage = fields.Float(string='Percentage', required=True, default=100.0)
    name = fields.Char(string='Name', related='account_id.name', readonly=False)
    tag_id = fields.Many2one('account.analytic.tag', string="Parent tag", required=True)

    _sql_constraints = [
        ('check_percentage', 'CHECK(percentage >= 0 AND percentage <= 100)',
         'The percentage of an analytic distribution should be between 0 and 100.')
    ]

一个简单的示例--唯一约束

class BlogTagCategory(models.Model):
    _name = 'blog.tag.category'
    _description = 'Blog Tag Category'
    _order = 'name'

    name = fields.Char('Name', required=True, translate=True)
    tag_ids = fields.One2many('blog.tag', 'category_id', string='Tags')

    _sql_constraints = [
        ('name_uniq', 'unique (name)', "Tag category already exists !"),
    ]

练习--添加SQL约束

添加以下约束到对应模型:

  • 房产预期价格必须为正数
  • 房产售价必须为正数
  • 报价必须为正数
  • 房产标签名称和类型名称必须唯一

使用-u estate选项重新启动服务器以查看结果。请注意,可能存在阻止设置SQL约束的数据。可能会弹出类似以下内容的错误消息:

ERROR rd-demo odoo.schema: Table 'estate_property_offer': unable to add constraint 'estate_property_offer_check_price' as CHECK(price > 0)

例如,如果某些报价的价格为零,则无法应用约束。可以删除、修正有问题的数据以应用新的约束。

修改odoo14\custom\estate\models\estate_property.py,添加SQL约束

    _sql_constraints = [
        ('check_expected_price', 'CHECK(expected_price > 0)', 'expected price should be positive.'),
        ('check_selling_price', 'CHECK(selling_price > 0)', 'selling price should be positive.')
    ]

注意:当selling_price为null时,也通过CHECK(selling_price > 0)校验的

修改odoo14\custom\estate\models\estate_property_tag.py,添加SQL约束

    _sql_constraints = [('check_tag', 'unique(name)', 'Tag name must be unique !')]

修改odoo14\custom\estate\models\estate_property_type.py,添加SQL约束

    _sql_constraints = [('check_name', 'unique(name)', 'Type name must be unique !')]

重启服务验证

预期效果动画:https://www.odoo.com/documentation/14.0/zh_CN/_images/sql_01.gif

odoo 开发入门教程系列-约束(Constraints)

https://www.odoo.com/documentation/14.0/zh_CN/_images/sql_02.gif

odoo 开发入门教程系列-约束(Constraints)

Python

参考: 主题关联文档可查看constrains().

SQL约束是确保数据一致性的有效方法。然而,可能需要进行更复杂的检查,这需要Python代码。在这种情况下,我们需要一个Python约束。

Python约束定义为用 constrains()修饰的方法,并在记录集上调用。修饰符指定约束中涉及哪些字段。当修改这些字段中的任何字段时,将自动计算约束。如果不满足该方法的恒定式,则该方法将引发异常:

from odoo.exceptions import ValidationError
...

@api.constrains('date_end')
def _check_date_end(self):
    for record in self:
        if record.date_end < fields.Date.today():
            raise ValidationError("The end date cannot be set in the past")
    # all records passed the test, don't return anything

一个简单的示例

    @api.constrains('quantity')
    def check_quantity(self):
        for quant in self:
            if quant.location_id.usage != 'inventory' and quant.lot_id and quant.product_id.tracking == 'serial' \
                    and float_compare(abs(quant.quantity), 1, precision_rounding=quant.product_uom_id.rounding) > 0:
                raise ValidationError(_('The serial number has already been assigned: \n Product: %s, Serial Number: %s') % (quant.product_id.display_name, quant.lot_id.name))

练习--添加Python约束

添加售价不能低于预期价格90%的约束

提示: 报价生效前,保持售价为0。你需要对校验进行微调,以便把这个考虑在内。

警告

当和浮点数打交道时,总是使用从 odoo.tools.float_utils导入的float_compare()float_is_zero()方法

确保每次售价或者预期价格改变时,自动触发约束

修改odoo14\custom\estate\models\estate_property.py

导入 ValidationError

from odoo.exceptions import ValidationError

最末尾添加以下代码

    @api.constrains('selling_price', 'expected_price')
    def _check_selling_price(self):
        for record in self:
            if record.selling_price < self.expected_price * 0.9:
                raise ValidationError("selling price can`t not lower then 90 percent of expected price")

重启服务,浏览器中验证

预期效果动画:https://www.odoo.com/documentation/14.0/zh_CN/_images/python.gif

odoo 开发入门教程系列-约束(Constraints)

SQL约束通常比Python约束更效率。当性能很重要时,总是首选SQL约束而不是Python约束。

原文链接:https://www.cnblogs.com/shouke/p/17253382.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:odoo 开发入门教程系列-约束(Constraints) - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • Python安装图文教程 Pycharm安装教程

    下面是Python安装和Pycharm安装的详细教程: Python安装教程 1. 下载Python安装包 访问Python官网 http://www.python.org/downloads/ ,选择适合你操作系统的Python安装包下载。一般来说,你应该下载最新的稳定版Python 3.x 版本。 2. 安装Python 双击下载的Python安装包,按…

    python 2023年5月30日
    00
  • python创建属于自己的单词词库 便于背单词

    Python创建属于自己的单词词库便于背单词 在本攻略中,我们将介绍如何使用Python创建属于自己的单词词库,以便于背单词。我们将使用Python的文件操作和字符串处理功能来实现这个过程。 步骤1:创建单词列表 使用以下代码可以创建单词列表: words = [‘apple’, ‘banana’, ‘cherry’, ‘date’, ‘elderberry…

    python 2023年5月15日
    00
  • 什么有那么多人选择Python,真的有那么好吗?

    为什么有那么多人选择Python,真的有那么好吗? Python是一门现代化的编程语言,因其简单易学、易用、开源、跨平台、功能强大和丰富的生态系统而备受欢迎。接下来,我们将详细讲解Python的优点。 1. 简单易学 Python语言的语法简单、清晰,排版规范,读起来像英语一样流畅自然,没有太多瑣碎的符号和花哨的编码机制,提供了极高的可读性和可维护性,是一门…

    python 2023年6月7日
    00
  • python datetime时间格式的相互转换问题

    下面是关于Python datetime时间格式的相互转换问题的详细攻略。 什么是Python datetime 在Python中,datetime模块提供了一系列用于处理日期和时间的函数。其中,datetime类是最常用的类,它可以表示一个具体的日期和时间,包括年、月、日、时、分、秒和微秒。 Python datetime类型的表示方法 datetime类…

    python 2023年6月2日
    00
  • 如何通过雪花算法用Python实现一个简单的发号器

    下面是详细讲解“如何通过雪花算法用Python实现一个简单的发号器”的完整攻略,包含两个示例说明。 雪花算法简介 雪花算法是一种用于生成唯一ID的算法。它可以生成全局唯一的ID,适用于分布式系统中的唯一标识符。 雪花算法实现 下面是Python实现雪花算法的代码: import time class Snowflake: def __init__(self,…

    python 2023年5月14日
    00
  • python-try-except:pass的用法及说明

    当我们在使用Python编写程序过程中,经常会遇到一些异常错误,如文件找不到,除数为0等。为了避免这些错误导致程序异常终止,可以使用 try 和 except 语句来处理异常情况。 try 语句的工作原理是,首先执行 try 后面的语句块,如果执行成功,就直接跳过 except 语句;如果执行过程中出现了异常,则跳转到 except 语句块中处理异常。 如果…

    python 2023年5月13日
    00
  • 使用python编写一个语音朗读闹钟功能的示例代码

    编写语音朗读闹钟的示例代码需要以下步骤: 步骤一:安装必要的库 首先,需要安装Python的pygame和pyttsx3库(注意pyttsx3库需要安装Microsoft Visual C++ 14.0),在命令行中输入以下命令安装: pip install pygame pyttsx3 步骤二:编写基本框架 接下来,我们来编写一个基本的框架,包括导入所需的…

    python 2023年5月19日
    00
  • python实现nao机器人手臂动作控制

    让我为你详细讲解 “Python实现Nao机器人手臂动作控制” 的完整攻略。 概览 Nao机器人是一款流行的图形化机器人,其手臂是该机器人的核心组件之一。在本教程中,我们将展示如何使用Python编程语言实现Nao机器人手臂的运动控制。 步骤1: 安装Python SDK 在开始之前,我们需要安装Nao机器人的Python SDK,这可以在Aldebaran…

    python 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部