Odoo 8-记录浏览等效于新的api



我阅读了Odoo 8新的api文档,但找不到(如果有的话)。当你有模型id/ids时,如何使用新的api直接浏览记录?

例如,假设我想浏览res.partner模型并拥有ID列表:ids = [1, 2, 3]

使用旧的api,你可以这样做:

partners = self.pool.get('res.partner').browse(cr, uid, ids)

有了新的api,我能想到的唯一方法就是在返回记录时使用搜索(而不是像旧api中那样使用id),如下所示:

partners = self.env['res.partner'].search([('id', 'in', ids)])

这给出了相同的结果,但我想知道性能(是一样的吗?)和方便性(为了避免使用搜索,当你已经知道id时,只需要浏览记录)?

或者搜索是新api中需要浏览记录时使用的首选方式?

您仍然可以将browse与新的api一起使用。这样做的理由要少得多,因为使用新的API,您通常处理的是记录集,而不是数字id列表。但你绝对可以在你真正需要的时候使用browse

partner_ids = [1, 2, 3]
partners = self.env['res.partner'].browse(partner_ids)

class Verify_Time(models.Model):_name='verify.time'

@api.model
def default_get(self, fields_name):
    update_ids = []
    data = super(Verify_Time, self).default_get(fields_name)
    if self._context.get('active_id'):
        student_id = self._context.get('active_id')
        for record in self.env['student.student'].browse(student_id):
            for time_record in record.time_table_ids:
                update_ids.append((0,0,{'standared_id':time_record.standared_id.id,
                                        'subject_id':time_record.subject_id.id,
                                        'start_time':time_record.start_time,
                                        'end_time':time_record.end_time}))
    data['s_time_ids'] = update_ids
    return data
s_time_ids = fields.One2many('s.time', 'verify_id', 'Time')
verify = fields.Selection(VERIFY, 'Verified?')

类S_Time(models.Model):_name=".time"

verify_id = fields.Many2one('verify.time', 'Verify')
serial_no = fields.Integer('#')
standared_id = fields.Many2one('standared.standared', 'Standared')
subject_id = fields.Many2one('section.section', 'Subject')
start_time = fields.Datetime('Start Time')
end_time = fields.Datetime('End Time')

最新更新