zoukankan      html  css  js  c++  java
  • odoo8 和odoo10区别

    V8  函数:'sale_order_count': fields.function(_sale_order_count, string='# of Sales Order', type='integer'),

    def _sale_order_count(self, cr, uid, ids, field_name, arg, context=None):
    res = dict(map(lambda x: (x,0), ids))
    # The current user may not have access rights for sale orders
    try:
    for partner in self.browse(cr, uid, ids, context):
    res[partner.id] = len(partner.sale_order_ids) + len(partner.mapped('child_ids.sale_order_ids'))
    except:
    pass
    return res

    V10 函数:sale_order_count = fields.Integer(compute='_compute_sale_order_count', string='# of Sales Order')

    def _compute_sale_order_count(self):
    sale_data = self.env['sale.order'].read_group(domain=[('partner_id', 'child_of', self.ids)],
    fields=['partner_id'], groupby=['partner_id'])
    # read to keep the child/parent relation while aggregating the read_group result in the loop
    partner_child_ids = self.read(['child_ids'])
    mapped_data = dict([(m['partner_id'][0], m['partner_id_count']) for m in sale_data])
    for partner in self:
    # let's obtain the partner id and all its child ids from the read up there
    item = next(p for p in partner_child_ids if p['id'] == partner.id)
    partner_ids = [partner.id] + item.get('child_ids')
    # then we can sum for all the partner's child
    partner.sale_order_count = sum(mapped_data.get(child, 0) for child in partner_ids)


    首先从定义就变化了 function 和compute='_compute_sale_order_count'




    v10 调用API比较多

  • 相关阅读:
    计算fibonacci数(多种方法)
    数组求和(两种方法)
    C语言二级指针(指向指针的指针)
    唯品会海量实时OLAP分析技术升级之路
    hive 调优(一)coding调优
    supsplk 服务器被植入木马 挖矿 cpu使用 700%
    OPTS参数设置
    Yarn 内存分配管理机制及相关参数配置
    hive on tez 任务失败
    hive 调优(三)tez优化
  • 原文地址:https://www.cnblogs.com/1314520xh/p/9115466.html
Copyright © 2011-2022 走看看