国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Odoo中如何生成唯一不重復的序列號詳解

2020-02-22 23:12:25
字體:
來源:轉載
供稿:網友

前言

最近在做的項目中有一個需求是要讓某個字段值根據記錄產生的日期和一定的組合規則按順序生成一個序列號,這個序列號不可重復,這原本是一個很常見的需求,沒有多想就寫好了。由于沒有考慮到并發的情況,到后面測試的時候才發現一個比較嚴重的問題,如果用戶同時操作產生的記錄,生成的序列號會出現重復。

經過討論和思考后有幾種解決方案,一是在數據庫表層加鎖,一是采用類似 redis 的消息隊列,還有就是通過文件鎖達到數據庫排他鎖的目的,鑒于時間和項目當前的情況,最后采用了通過文件鎖實現這個需求。

其實除了以上幾種方式,Odoo 本身就有一個模型(ir.sequence)是用于生成序列的,可以很方便地實現這個需求,因為之前一直沒有接觸過這個模塊,還是在項目之后的階段同事使用到了并且告訴我之后才知道原來有這么個好東西的存在。在這里我將會把我原本通過文件鎖實現的方式和通過 Odoo 自帶的ir.sequence實現的方式都記錄下來。

給文件加鎖 - fcntl

fcntl是 Python 標準庫里的一個模塊,用來對文件進行加鎖的操作。在實現中主要用到的是下面這個函數:

def flock(fd, operation): """ flock(fd, operation) Perform the lock operation op on file descriptor fd. See the Unix  manual page for flock(2) for details. (On some systems, this function is emulated using fcntl().) """ pass

其中fd是文件描述符,operation為鎖的操作,總共有4種:

fcntl.LOCK_EX - 排他鎖 fcntl.LOCK_NB - 非阻塞鎖 fcntl.LOCK_SH - 共享鎖 fcntl.LOCK_UN - 解鎖

關于fcntl的其他具體內容請查看 官方標準庫文檔 。

下面來看一下具體的實現,在給出代碼之前,先描述一下需求,假設模型中有一個字段sn用于存儲按一定規則生成的序列號,序列號的組成規則如下:

固定的前綴SN 取記錄生成的日期組成的6位數字%y%m%d,如2017年12月8日取值為171208 最后是3位的流水號,從001開始遞增 生成的序列號不能有重復 最后的3位流水號每天自動重置,從001開始遞增(這個需求涉及到一些擴展,故此文將不實現這一需求)

需求很簡單,也很清楚了,下面就上代碼開始具體的實現。首先創建一個模塊demo_sequence:

./odoo-bin scaffold demo_sequence

然后在模塊的目錄下創建數據文件目錄data/,在目錄下創建一個data.xml文件,在后面會用到;繼續在模塊目錄下創建靜態文件目錄static/,在目錄下創建一個空文件SN.LOCK用作加鎖的文件對象。完成之后的目錄結構如下:

demo_sequence├── __init__.py├── __manifest__.py├── controllers│ ├── __init__.py│ └── controllers.py├── data│ └── data.xml├── demo│ └── demo.xml├── models│ ├── __init__.py│ └── models.py├── security│ └── ir.model.access.csv├── static│ └── SN.LOCK└── views├── templates.xml└── views.xml            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 资中县| 河北区| 陆河县| 屯留县| 增城市| 铁岭县| 图木舒克市| 河间市| 茶陵县| 谢通门县| 文昌市| 巫山县| 射阳县| 增城市| 鲁山县| 田林县| 富宁县| 石阡县| 沾益县| 惠州市| 无锡市| 周至县| 株洲市| 峨边| 凯里市| 芷江| 阜平县| 新野县| 嘉禾县| 郎溪县| 通山县| 朝阳市| 黔南| 米脂县| 宾川县| 肥东县| 崇仁县| 巴塘县| 乳源| 南丰县| 林周县|