升级脚本

升级脚本是一个包含名为 migrate() 函数的 Python 文件,升级过程在模块更新期间调用该函数。

migrate(cr, version)
参数
  • cr (Cursor) – 当前数据库游标

  • version (str) – 模块的已安装版本

通常,此函数执行一个或多个SQL查询,并且还可以访问Odoo的ORM,以及 Upgrade utils

编写升级脚本

升级脚本遵循特定的树形结构,其命名约定决定了它们何时被执行。

升级脚本路径的结构为 $module/migrations/$version/pre,post,end-*.py,其中 $module 是脚本将运行的模块,$version 是模块的完整版本(包括 Odoo 的主版本和模块的次版本),而 {pre|post|end}-*.py 是需要执行的文件。文件的名称将决定该模块和版本的 阶段 和执行顺序。

注解

从 Odoo 13 开始,升级脚本的顶级目录也可以命名为 upgrades。这种命名方式更受推荐,因为它具有正确的含义:migrate 可能会与 moving out of Odoo 混淆。因此 $module/upgrades/$version/ 也是有效的。

注解

升级脚本仅在模块更新时执行。因此,$version 目录中设置的模块次要版本需要高于模块的已安装版本,并且等于或低于模块的更新版本。

Example

自定义模块 awesome_partner 升级到 Odoo 17 版本 2.0 的升级脚本的目录结构。

awesome_partner/
|-- migrations/
|   |-- 17.0.2.0/
|   |   |-- pre-exclamation.py

两个升级脚本示例,内容来自 pre-exclamation.py 文件,在合作伙伴名称末尾添加 “!”:

import logging

_logger = logging.getLogger(__name__)


def migrate(cr, version):
    cr.execute("UPDATE res_partner SET name = name || '!'")
    _logger.info("Updated %s partners", cr.rowcount)
import logging
from odoo.upgrade import util

_logger = logging.getLogger(__name__)


def migrate(cr, version):
    env = util.env(cr)

    partners = env["res.partner"].search([])
    for partner in partners:
        partner.name += "!"

    _logger.info("Updated %s partners", len(partners))

请注意,在第二个示例中,脚本利用了 Upgrade utils 来访问 ORM。查阅文档以了解更多关于此库的信息。

升级脚本的阶段

升级过程包括每个模块每个版本的三个阶段:

  1. 模块加载前的预阶段。

  2. 后阶段,在模块及其依赖项加载并更新之后。

  3. 结束阶段,在该版本的所有模块都已加载并更新之后。

升级脚本根据其文件名的第一部分分组到相应的阶段。在每个阶段内,文件按照其词法顺序执行。

一个版本中一个模块的示例脚本的执行顺序

  1. pre-10-do_something.py

  2. pre-20-something_else.py

  3. post-do_something.py

  4. post-something.py

  5. end-01-migrate.py

  6. end-migrate.py