Monthly Archive: December, 2017

Odoo 使用 ir.sequence 生成序列号

在Odoo里面,默认提供了ir.sequence这样一个模块,他的作用就是一个序号生成器。在这次的项目中刚好用到了,这里就记录一下。

创建序号

打开 data/data.xml 写入如下代码:

<?xml version="1.0" encoding="utf-8"?>
<odoo>
   <data noupdate="True">
      <record id="contract_number" model="ir.sequence">
         <field name="name">预算编号</field>
         <field name="code">budget.number</field>
         <field name="prefix">HT%(year)s%(month)s%(day)s</field>
         <field name="suffix">号</field>
         <field name="padding">1</field>
      </record>
   </data>
</odoo>

参数说明:

  • name - 名字,随便叫什么都行
  • code - 调用生成编码的 Key,需保证唯一性
  • prefix - 前缀,可以是固定的字面量也可以是组合参数
  • padding - 序列递增的位数

调用

将data/data.xml加入到__manifest__.py的data列表中。

budget_num = fields.Char(string=u'预算编号', copy=False, readonly=True, default=lambda x: _('New'))

@api.model
def create(self, vals):
	""" 保存方法重写 """
	if not vals.get('name', False) or vals['name'] == _('New'):
		vals['budget_num'] = self.env['ir.sequence'].next_by_code('budget.number')
	return super(Budget, self).create(vals)

Odoo x2many 赋值

many2many

  • (0,0,{values})  根据values里面的信息新建一个记录。
  • (1,ID,{values})  更新id=ID的记录(写入values里面的数据)
  • (2,ID)  删除id=ID的数据(调用unlink方法,删除数据以及整个主从数据链接关系)
  • (3,ID)  切断主从数据的链接关系但是不删除这个数据
  • (4,ID)  为id=ID的数据添加主从链接关系。
  • (5)  删除所有的从数据的链接关系就是向所有的从数据调用(3,ID)
  • (6,0,[IDs])  用IDs里面的记录替换原来的记录(就是先执行(5)再执行循环IDs执行(4,ID))
[(6, 0, [8, 5, 6, 4])] 设置 many2many to ids [8, 5, 6, 4]

one2many

  • (0, 0,{ values })  根据values里面的信息新建一个记录。
  • (1,ID,{values})  更新id=ID的记录(对id=ID的执行write 写入values里面的数据)
  • (2,ID)  删除id=ID的数据(调用unlink方法,删除数据以及整个主从数据链接关系)
new_lines = self.env['test.person']
data = {
    'name' = 'joy',
    'age' = 10
}
new_line = new_lines.new(data)
new_lines += new_line
self.one2many_name += new_lines
data_list = list()
data = {
    'name' = 'joy',
    'age' = 10
}
data_list.append((0, False, data))
self.one2many_field = data_list

Archives