创建自定义报告

SQL 视图是一种创建自定义报告的技术,用于显示现有模型字段和视图无法展示的数据。换句话说,这种技术有助于避免为了数据分析目的而创建和计算不必要的额外字段。

创建模型

SQL 视图的创建方式与标准模型类似:

from odoo import fields, models


class ModuleReport(models.Model):
    _name = 'module.report'
    _description = "Module Report"
    _rec_name = 'module_field'
    _auto = False

其中属性:

  • _auto = False 表示我们不希望将模型存储在数据库中

  • _rec_name 表示模型中哪个字段代表记录的名称(即在打开记录的表单视图时导航面包屑中使用的名称)

其字段的定义方式与标准模型相同,只是每个字段都标记为 readonly=True

注解

别忘了将您的新模型添加到安全文件中。

填充模型

有两种方法可以填充 SQL 视图的表:

  • 重写 BaseModel.init() 方法,

  • 设置 _table_query 属性。

无论使用哪种方法,都会执行 SQL 查询来填充模型。因此,可以使用任何 SQL 命令来收集和/或计算所需的数据,同时请记住您正在绕过 ORM(即,如果尚未阅读,请务必查看 Odoo 中的安全性 )。从 SELECT 返回的列将填充模型的字段,因此请确保列名与字段名匹配,或者使用匹配的别名。

在大多数情况下,重写 BaseModel.init() 方法是标准且更好的选择。它需要导入 tools,通常编写如下:

def init(self):
    tools.drop_view_if_exists(self.env.cr, self._table)
    self.env.cr.execute("""CREATE or REPLACE VIEW %s as (
                           SELECT
                              %s
                           FROM
                              %s
        )""" % (self._table, self._select(), self._from()))

tools.drop_view_if_exists 确保在执行 SQL 查询时不会创建冲突的视图。通常会将查询的不同部分分开,以便于模型扩展。虽然查询如何拆分到方法中没有标准化,但至少 _select_from 方法是常见的,并且这些方法都会返回字符串。

使用模型

SQL 视图的视图和菜单项的创建和使用方式与其他 Odoo 模型相同。您已经准备好开始使用您的 SQL 视图了。祝您玩得开心!

额外提示

小技巧

SQL 视图中的一个常见错误是没有考虑到由于表连接(JOIN)导致的某些数据重复。这可能会在使用字段的 aggregator 和/或透视表视图时导致计数错误。最好使用足够的数据测试您的 SQL 视图,以确保结果字段值符合预期。

小技巧

如果您有一个字段不希望作为度量值(即在透视表或图表视图中),请为其添加 store=False ,这样它就不会显示。