如何在 Odoo 16 中添加計算字段的搜索過濾器


首先,了解 Odoo 使用計算字段的原因很重要。當我們需要從其他字段獲取計算值或計算值時,就會使用計算字段。換句話說,不是從數據庫中檢索值,而是可以使用函數計算字段的值。計算字段的一個例子是產品總金額,即通過將產品價格乘以產品總數得出。即,總額等于產品價格乘以產品數量。

在Odoo 16中,計算字段默認不保存在數據庫中。因此,在某些情況下我們需要使用這些計算字段進行搜索或過濾。

主要介紹如何在 Odoo 16 中為非存儲計算字段添加搜索功能來實現這一點。

在 Odoo 中,計算字段可以以兩種不同的方式存儲。通過設置 store=True,我們可以創建商店字段。此外,您可以通過在字段上設置來使用搜索功能。

我將使用銷售訂單中的 is_expired 字段作為示例來說明這一點。

我們沒有按 is_expired 字段進行過濾的選項。讓我們通過繼承銷售訂單來添加它?

?

class SaleOrder(models.Model):_inherit = "sale.order"is_expired = fields.Boolean(string="Is Expired",                  compute='_compute_is_expired',store=True)

在這里,我們為字段添加了字段屬性 store=True。(注意:如果維護 store=True,則只有在依賴字段的值發生變化時,計算函數才會運行)。

使用計算字段進行搜索的第二種方法是向計算字段添加搜索功能,如下面提供的代碼所示。

?

is_expired = fields.Boolean(string="Is Expired", compute='_compute_is_expired',search = '_search_is_expired')
def _search_is_expired(self, operator, value):today = fields.Date.today()records = self.env['sale.order'].search([('validity_date', '<', today)])return [('id', 'in', records.ids)]

?我們需要繼承 XML 中的搜索視圖并向其中添加過濾器。

<record id="is_expired_view_search_inherit_quotation" model="ir.ui.view"><field name="name">is.expired.search.view</field><field name="model">sale.order</field><field name="inherit_id" ref="sale.view_sales_order_filter"/><field name="mode">primary</field><field name="priority">32</field><field name="arch" type="xml"><xpath expr="//filter[@name='my_sale_orders_filter']" position="after"><filter name="is_expired" string="Is Expired"  domain="[('is_expired',  '=', True)]"/></xpath>
</field>
</record>

同樣,我們不僅可以為布爾字段添加搜索功能,還可以為其他類別字段的計算字段添加搜索功能。

這是如何在 Odoo 中包含計算字段的搜索過濾器。我們將編寫代碼來計算計算函數中的值。此外,搜索函數指定應返回的內容。當選擇 store=True 時,數據將保存到數據庫。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/40842.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/40842.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/40842.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

EtherCAT通訊介紹

一、EtherCAT簡介 EtherCAT&#xff08;Ethernet for Control Automation Technology&#xff09;是一種實時以太網技術&#xff0c;是由德國公司Beckhoff Automation在2003年首次推出的。它是一種開放的工業以太網標準&#xff0c;被設計用于滿足工業自動化應用中的高性能和低…

匯聚榮拼多多評價好不好?

匯聚榮拼多多評價好不好?在探討電商平臺的口碑時&#xff0c;用戶評價是衡量其服務質量和商品質量的重要指標。拼多多作為國內領先的電商平臺之一&#xff0c;其用戶評價自然成為消費者選擇購物平臺時的參考依據。針對“匯聚榮拼多多評價好不好?”這一問題&#xff0c;可以從…

Vue3 Hooks 用法 scrollTop, mousemoveHandler,useCountDown

三個實例來自 learn_vue: 【教學工程】學習vue2/vue3 (gitee.com) 目錄 1. 何為Hooks 2. 使用場景 3. 常見的 Hooks 函數 4. 實例 4.1簡易hook 例子 4.2 自定義scrolltop例子 4.3 mousemoveHandler例子 4.4 useCountDown例子 1. 何為Hooks Hooks 是一種函數&#xff0c;用于…

vue css 鏈式布局模式

<div class"pp-wrap"> <div class"pp-left"><!--跳活動反思--><div class"even-box" v-for"(item,index) in trackingPtoPLeftList" :key"index" click"jumpReview(item)"><div …

echarts柱狀選中shadow陰影背景寬度設置

使用line&#xff0c;寬度增大到所需要的寬度&#xff0c;設置下顏色透明度就行 tooltip: {trigger: axis,//把陰影的層級往下降z:-15,axisPointer: {type: line,lineStyle: {color: rgba(150,150,150,0.3),width: 44,type: solid,},}, }, series: [{type: bar,barWidth:20,//…

python自動化辦公之BeautifulSoup爬取并解析html文本

用到的庫&#xff1a;BeautifulSoup 實現效果&#xff1a;爬取網站內容&#xff0c;拿到html文本并解析html文本 代碼&#xff1a; 先爬取 # 先導入requests包 import requests urlhttps://www.baidu.com responserequests.get(url) # 做1個斷言&#xff0c;如果執行成功&a…

【C語言】—— 文件操作(上)

【C語言】—— 文件操作&#xff08;上&#xff09; 一、 為什么使用文件二、 什么是文件2.1、 程序文件2.2、 數據文件2.3、 文件名2.4、二進制文件與文本文件 三、 文件的打開和關閉3.1、流和標準流&#xff08;1&#xff09;流&#xff08;2&#xff09;標準流 3.2、文件指針…

64.函數參數和指針變量

目錄 一.函數參數 二.函數參數和指針變量 三.視頻教程 一.函數參數 函數定義格式&#xff1a; 類型名 函數名(函數參數1,函數參數2...) {代碼段 } 如&#xff1a; int sum(int x&#xff0c;int y) {return xy; } 函數參數的類型可以是普通類型&#xff0c;也可以是指針類…

Python可實現各種算法庫之algorithms使用詳解

概要 在軟件開發和計算機科學領域,算法是解決問題的核心工具。Python 作為一種廣泛使用的編程語言,提供了多種內置和第三方庫來實現各種算法。algorithms 庫是一個集合了多種常用算法和數據結構的 Python 庫,旨在幫助開發者快速實現和應用這些算法。本文將詳細介紹 algorit…

QT元對象系統的用法技巧

文章目錄 聲明對象屬性獲取對象的屬性和方法通過對象名稱查找對象判斷對象的繼承關系給類添加額外的信息Qt的元對象系統是Qt框架的一個核心特性,它為對象提供了運行時類型信息、屬性系統、信號和槽機制以及動態屬性功能。這個系統是由Qt的元對象編譯器(MOC)支持的,MOC是一個預…

代碼隨想錄-DAY②-數組——leetcode 977 | 209

977 思路 使用兩個指針分別指向位置 0 和 n?1&#xff0c;每次比較兩個指針對應的數&#xff0c;選擇較大的那個逆序放入答案并移動指針。這種方法無需處理某一指針移動至邊界的情況。 時間復雜度&#xff1a;O(n) 空間復雜度&#xff1a;O(1) 代碼 class Solution { pub…

SpringCloud Feign 報錯 Request method ‘POST‘ not supported 的解決辦法

通過SpringCloud Feign 調用其他項目或微服務的接口方法時報Request method ‘POST‘ not supported 的錯誤&#xff1a; 問題出現原因&#xff1a; 可能的原因是 Feign 默認使用的請求方法為 POST&#xff0c;而不是 GET。另外也有可能是由于消費方法和接口方法使用的注解不…

拼多多店鋪電話采集軟件使用步驟解析

要快速訪問拼多多店鋪鏈接&#xff0c;可以使用一個提供快速訪問功能的拼多多店鋪鏈接程序。以下是使用步驟的簡要解析&#xff1a; 下載和安裝程序&#xff1a;首先&#xff0c;在可靠的下載平臺或官方網站上下載并安裝拼多多店鋪鏈接程序。確保選擇一個可信賴的程序&#xff…

Dialog設置背景透明和尺寸

class TestDialog(context: Context?,var clickListener: OnClickCallBack) : Dialog(context!!) {lateinit var binding:TestDialogBindingoverride fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)binding TestDialogBinding.inflate(Lay…

軟件測試面試題:Redis的五種數據結構,以及使用的場景是什么?

字符串&#xff08;Strings&#xff09;&#xff1a;簡單直接&#xff0c;就像記事本一樣&#xff0c;用來存儲和快速訪問簡單的數據&#xff0c;比如緩存網頁或者保存用戶會話信息。 列表&#xff08;Lists&#xff09;&#xff1a;有序的數據集合&#xff0c;適合用來存儲按…

Ollama基于Casaos一鍵部署,并接入Dify知識庫,無需再為API付費

什么是Ollama Ollama是一個開源的大型語言模型服務工具&#xff0c;它幫助用戶快速的運行大模型。浪浪云將它做為一鍵部署通過簡單的安裝&#xff0c;用戶可以執行一條命令就可以運行開源大型語言模型&#xff0c;如 llama3 ,通以千問。極大地簡化了部署和管理LLM的過程&#x…

modelscope可控細節的長文檔摘要

modelscope可控細節的長文檔摘要嘗試 本文的想法來自今年OpenAI cookbook的一篇實踐&#xff1a;summarizing_long_documents&#xff0c;目標是演示如何以可控的細節程度總結大型文檔。 如果我們想讓大語言模型總結一份長文檔&#xff08;例如 10k 或更多tokens&#xff09;&…

6個步驟實現Postman接口壓力測試(建議收藏)

&#x1f345; 視頻學習&#xff1a;文末有免費的配套視頻可觀看 &#x1f345; 點擊文末小卡片 &#xff0c;免費獲取軟件測試全套資料&#xff0c;資料在手&#xff0c;漲薪更快 這里講是postman做接口并發測試&#xff0c;基礎用法不做贅述 1、第一步接口可以通的情況下點擊…

Proteus-51單片機-DS18B20多點測溫

DS18B20多點測溫 一、Proteus仿真演示 每個DS18B20都有一個唯一的64位序列號,這使得在同一總線上可以掛載多個傳感器,無需額外的地址分配。主機(通常為單片機)通過特定的時序控制,可以依次讀取各個DS18B20的溫度數據,實現分布式測溫。 二、代碼特點 三、開發環境介紹 本…

基于Arduino平臺開源小車的初步使用體驗

創作原因&#xff1a;偶然有機會接觸到基于Arduino平臺的開源智能小車&#xff0c;初步使用后與大家分享。因使用時間不常&#xff0c;可以純當個樂子看看&#xff0c;感謝大家的閱讀&#xff01; 圖&#xff1a;一款基于Arduino平臺的開源小車 一、開發環境 Misly&#xff1…