码迷,mamicode.com
首页 > 其他好文 > 详细

odoo 创建一条记录的时候自动增加一个序列号

时间:2017-07-02 19:03:39      阅读:2252      评论:0      收藏:0      [点我收藏+]

标签:nbsp   分享   ready   .com   ber   set   条件   next   get   

第一步:

在odoo开发者模式,进入配置设置添加一个序列号,sequence ocde 这个地方的值要与代码里相同

  技术分享

 开始是在代码里这样设置的,cwbh是财务编号的字段需求是每次新增自动加1 

cwbh = fields.Char(string=‘Number‘, required=True, copy=False, readyonly= True default=lambda self:self.env[‘ir.sequence‘].next_by_code(‘dycrm.cwbh‘))

重新启动代码可以执行但是有个bug就是启动的时候他会增加一次,保存的时候会增加一次。后来经过思远老师的指点发现,把
readyonly= False 就好了。但是不能让用户修改满足不了需求,于是想在创建代码的时候自动增加sequence序列
    # def create(self, vals):
    #    if not vals.get(‘cwbh‘):
    #         vals[‘cwbh‘] = self.env[‘ir.sequence‘].next_by_code(‘dycrm.cwbh‘)
    #    return super(dycrm, self).create(vals)

但是在保存的时候就会报一个错误,可能是因为我没有继承造成的,但是源码里也没有继承还是能够实现

技术分享

最后新建了一个自启动aciton,创建一条记录的时候触发python代码

技术分享

 



技术分享

 

param = (env[ir.sequence].next_by_code(dycrm.cwbh),record.id)
#保存的时候根据record.id当前记录的id值,更新表的cwbh字段
env.cr.execute("update dycrm_main set cwbh=%s where id=%s"% param)

在odoo 开发模式auto aciton 保存条件的时候,是先保存后触发条件,所以可以直接根据新生产的记录id更新这条记录里的某个字段

env[‘ir.sequence‘].next_by_code(‘dycrm.cwbh‘)会自动生成一个序列根据第一步里的设置,在设置菜单里,要去掉self。

好了就这么多,有用方便的话,欢迎支付宝打赏哦。

 技术分享

本文为原创转载请注明。另推荐思远老师的odoo学习网站

 

 





odoo 创建一条记录的时候自动增加一个序列号

标签:nbsp   分享   ready   .com   ber   set   条件   next   get   

原文地址:http://www.cnblogs.com/zzzhhy/p/7106717.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!