升级脚本¶
升级脚本是一个包含名为 migrate()
函数的 Python 文件,升级过程在模块更新期间调用该函数。
通常,此函数执行一个或多个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。查阅文档以了解更多关于此库的信息。
升级脚本的阶段¶
升级过程包括每个模块每个版本的三个阶段:
模块加载前的预阶段。
后阶段,在模块及其依赖项加载并更新之后。
结束阶段,在该版本的所有模块都已加载并更新之后。
升级脚本根据其文件名的第一部分分组到相应的阶段。在每个阶段内,文件按照其词法顺序执行。
一个版本中一个模块的示例脚本的执行顺序
pre-10-do_something.py
pre-20-something_else.py
post-do_something.py
post-something.py
end-01-migrate.py
end-migrate.py