我阅读了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')