From 178d0e46ca277fa56c4fc8ade889ef6539d68b83 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?C=C3=A9dric=20Pigeon?= Date: Wed, 9 Jan 2019 13:42:30 +0100 Subject: [PATCH] [ADD] account_financial_report_web: add index on account_move_line to speed up report rendering --- account_financial_report_qweb/__manifest__.py | 2 +- .../models/__init__.py | 1 + .../models/account_move_line.py | 31 +++++++++++++++++++ 3 files changed, 33 insertions(+), 1 deletion(-) create mode 100644 account_financial_report_qweb/models/account_move_line.py diff --git a/account_financial_report_qweb/__manifest__.py b/account_financial_report_qweb/__manifest__.py index 5bebc5fd..e94adfed 100644 --- a/account_financial_report_qweb/__manifest__.py +++ b/account_financial_report_qweb/__manifest__.py @@ -5,7 +5,7 @@ # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). { 'name': 'QWeb Financial Reports', - 'version': '10.0.2.0.0', + 'version': '10.0.2.0.1', 'category': 'Reporting', 'summary': 'OCA Financial Reports', 'author': 'Camptocamp SA,' diff --git a/account_financial_report_qweb/models/__init__.py b/account_financial_report_qweb/models/__init__.py index b8a98686..75493a69 100644 --- a/account_financial_report_qweb/models/__init__.py +++ b/account_financial_report_qweb/models/__init__.py @@ -4,3 +4,4 @@ # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html). from . import account +from . import account_move_line diff --git a/account_financial_report_qweb/models/account_move_line.py b/account_financial_report_qweb/models/account_move_line.py new file mode 100644 index 00000000..fc81af61 --- /dev/null +++ b/account_financial_report_qweb/models/account_move_line.py @@ -0,0 +1,31 @@ +# -*- coding: utf-8 -*- +# Copyright 2019 ACSONE SA/NV () +# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).- +from odoo import api, models + + +class AccountMoveLine(models.Model): + _inherit = 'account.move.line' + + @api.model_cr + def init(self): + """ + The join between accounts_partners subquery and account_move_line + can be heavy to compute on big databases. + Join sample: + JOIN + account_move_line ml + ON ap.account_id = ml.account_id + AND ml.date < '2018-12-30' + AND ap.partner_id = ml.partner_id + AND ap.include_initial_balance = TRUE + By adding the following index, performances are strongly increased. + :return: + """ + self._cr.execute('SELECT indexname FROM pg_indexes WHERE indexname = ' + '%s', + ('account_move_line_account_id_partner_id_index',)) + if not self._cr.fetchone(): + self._cr.execute(""" + CREATE INDEX account_move_line_account_id_partner_id_index + ON account_move_line (account_id, partner_id)""")