如何解决序列字段 Odoo
我想添加一个具有以下语法的序列字段 "name"
:"Alerte/date_creation/000x"
它会像:
"Alerte/14-07-2021/0001"
"Alerte/14-07-2021/0002"...
这里是我的python代码:
class StockAlert(models.Model):
_name = "stock.alert"
_inherit = ['mail.thread','mail.activity.mixin']
_rec_name = "name"
name = fields.Char(string="Nom",default="New")
date_creation = fields.Date("Date de création",default=datetime.Now().strftime('%Y-%m-%d'))```
解决方法
通过您自己的代码(坏主意)或使用 ir.sequence 管理自己的两种可能性。
在这两种情况下,您将使用方法 create
自我管理
@api.model
def create(self,values):
res= super(YourClass,self).create(values)
res.write({name : f'Alerte/{current_date}/{res.id}'})
return res
此逻辑有效,但您使用了 2 个请求来执行此 1 个插入和 1 个更新。
使用ir.sequence
首先在 xml 文件中创建一个 ir.sequence:
<record id="seq_stock_alert" model="ir.sequence">
<field name="name">Stock alert sequence</field>
<field name="code">seq.stock.alert</field>
<field name="prefix">Alerte/%(y)s-%(month)s-%(day)s/</field>
<field name="padding">3</field>
</record>
下一步在你的python中
@api.model
def create(self,values):
values['name'] = self.env['ir.sequence'].next_by_code('seq.stock.alert') or _('New')
return super(YourClass,self).create(values)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。