Odoo12 ORM API ☞ Porting from the old API to the new API

2023-12-20 04:48
文章标签 api new orm old odoo12 porting

本文主要是介绍Odoo12 ORM API ☞ Porting from the old API to the new API,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Porting from the old API to the new API(从旧API移植到新API)

  • 在新API中应避免使用ids列表,而是使用记录集
  • 仍旧使用旧API编写的方法应由ORM自动转换,无需切换到旧API,只需将它们称为新API方法即可
  • *search()*返回一个记录集,例如查询其结果
  • fields.relatedfields.function由使用带有related =compute = 参数的普通字段类型替换
  • compute= 方法中使用 depends() 必须要完整,它必须列出计算方法使用的所有字段和子字段。depends依赖的字段多点(将在不需要的情况下重新计算字段)比不够了要好(将忘记重新计算字段然后值将不正确)
  • 删除计算字段上的所有onchange方法。当其中一个依赖项发生更改时,计算字段会自动重新计算,并且用于由客户端自动生成onchange
  • 装饰器model()和multi()用于在从旧的API上下文调用时进行转接,对于内部或纯新的api(例如计算),它们是无用的
  • 如果字段的 string= 是字段名称的标题版本:
name = fields.Char(string="Name")

  它没用,应该删除

  • multi = 参数在新API字段上不执行任何操作在相同结果的所有相关字段上使用相同的compute = 方法
  • 按名称(作为字符串)提供compute =,inverse =和search =方法,这使得它们可以被重写(不需要中间的 “trampoline” 函数)
  • 仔细检查所有字段和方法是否有不同的名称,在冲突时没有警告(因为Python在Odoo看到任何东西之前处理它)
  • 正常的new-api导入方式为 from odoo import fields, models. 如果需要兼容性装饰器 请使用 from odoo import api, fields, models
  • 避免使用*one()*装饰器,它可能不会达到预期效果
  • 去掉显式定义 create_uid, create_date, write_uid and write_date fields 字段: 它们现在被创建为常规的“合法”字段,并且可以像开箱即用的任何其他字段一样进行读写
  • 当不能直接转换(语义无法桥接)或“旧API”版本不可取,并且可以针对新API进行改进,可以使用v7()和v8()为相同的方法名称使用完全不同的“旧API”和“新API”实现。首先应使用旧的API样式定义该方法,并使用v7()进行修饰,然后应使用完全相同的名称重新定义它,但使用新的API样式并使用v8()进行修饰。来自旧API上下文的调用将被分派到第一个实现,并且来自新API上下文的调用将被分派到第二个实现。一个实现可以通过切换上下文来调用(并经常),调用另一个实现。

Danger!
使用这些装饰器使得方法极难覆盖并且难以理解和记录

  • _columns或_all_columns的使用应替换为_fields,它提供了对新式odoo.fields.Field实例(而不是旧式odoo.osv.fields._column)实例的访问。
    使用新API样式创建的非存储计算字段在_columns中不可用,只能通过_fields进行检查

  • 在方法中重新分配self可能是不必要的,可能会破坏翻译检查

  • 环境对象依赖于某些threadlocal状态,必须在使用之前进行设置。在尝试在尚未设置的上下文中使用新API时,有必要使用odoo.api.Environment.manage()上下文管理器,例如新线程或Python交互式环境:

>>> from odoo import api, modules
>>> r = modules.registry.RegistryManager.get('test')
>>> cr = r.cursor()
>>> env = api.Environment(cr, 1, {})
Traceback (most recent call last):...
AttributeError: environments
>>> with api.Environment.manage():
...     env = api.Environment(cr, 1, {})
...     print env['res.partner'].browse(1)
...
res.partner(1,)

Automatic bridging of old API methods(自动桥接旧的API方法)

初始化模型时,如果它们看起来像旧API样式中声明的模型,则会自动扫描和桥接所有方法。这种桥接使它们可以从新的API风格(new-API-style)方法中透明地调用。
如果第二个位置参数(在self之后)为cr或cursor,则方法被匹配为“旧API样式”。系统还识别第三个位置参数为uid或user,第四个为id或id。它还识别出存在任何称为上下文的参数。
从新的API上下文调用此类方法时,系统将自动填充当前Environment(对于cr, user and context)或当前记录集(对于id和ids)的匹配参数。
在极少数情况下,可以通过装饰旧式方法来定制桥接:

  • 通过使用noguess()完全禁用修饰、修饰方法将没有桥接,并且将从新旧API样式中以完全相同的方式调用方法:
  • 明确定义桥接方法,这主要是针对错误匹配的方法(因为参数以意想不到的方式命名):

cr()
 将在位置自动将当前光标前置到显式提供的参数
cr_uid()
 将自动将当前光标和用户的id添加到明确提供的参数中
cr_uid_ids()
 将自动将当前光标,用户的id和记录集的id添加到显式提供的参数
cr_uid_id()
 将循环遍历当前记录集并为每个记录调用该方法一次,将当前游标,用户的id和记录的id添加到显式提供的参数。
Danger!
从新的API上下文调用时,此包装器的结果始终是一个列表

  所有这些方法都有一个_context后缀版本(例如cr_uid_context()),它也通过关键字传递当前上下文。

  • 使用v7()和v8()的双重实现将被忽略,因为它们提供了自己的“桥接”

这篇关于Odoo12 ORM API ☞ Porting from the old API to the new API的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/514810

相关文章

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

使用Python实现调用API获取图片存储到本地的方法

《使用Python实现调用API获取图片存储到本地的方法》开发一个自动化工具,用于从JSON数据源中提取图像ID,通过调用指定API获取未经压缩的原始图像文件,并确保下载结果与Postman等工具直接... 目录使用python实现调用API获取图片存储到本地1、项目概述2、核心功能3、环境准备4、代码实现

无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案

《无法启动此程序因为计算机丢失api-ms-win-core-path-l1-1-0.dll修复方案》:本文主要介绍了无法启动此程序,详细内容请阅读本文,希望能对你有所帮助... 在计算机使用过程中,我们经常会遇到一些错误提示,其中之一就是"api-ms-win-core-path-l1-1-0.dll丢失

python通过curl实现访问deepseek的API

《python通过curl实现访问deepseek的API》这篇文章主要为大家详细介绍了python如何通过curl实现访问deepseek的API,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编... API申请和充值下面是deepeek的API网站https://platform.deepsee

Java对接Dify API接口的完整流程

《Java对接DifyAPI接口的完整流程》Dify是一款AI应用开发平台,提供多种自然语言处理能力,通过调用Dify开放API,开发者可以快速集成智能对话、文本生成等功能到自己的Java应用中,本... 目录Java对接Dify API接口完整指南一、Dify API简介二、准备工作三、基础对接实现1.

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Python中的魔术方法__new__详解

《Python中的魔术方法__new__详解》:本文主要介绍Python中的魔术方法__new__的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、核心意义与机制1.1 构造过程原理1.2 与 __init__ 对比二、核心功能解析2.1 核心能力2.2

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Python中__new__()方法适应及注意事项详解

《Python中__new__()方法适应及注意事项详解》:本文主要介绍Python中__new__()方法适应及注意事项的相关资料,new()方法是Python中的一个特殊构造方法,用于在创建对... 目录前言基本用法返回值单例模式自定义对象创建注意事项总结前言new() 方法在 python 中是一个