创建自定义报告¶
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
方法是常见的,并且这些方法都会返回字符串。
当视图依赖上下文时,使用 _table_query
属性。它通常编写如下:
@property
def _table_query(self):
return 'SELECT %s FROM %s' % (self._select(), self._from())
并且遵循与 BaseModel.init()
相同的 _select
和 _from
方法标准。
一个应该使用该属性而不是重写 BaseModel.init()
的例子是在多公司和多货币环境中,当用户在公司之间切换时,需要使用汇率转换与货币相关的金额。
使用模型¶
SQL 视图的视图和菜单项的创建和使用方式与其他 Odoo 模型相同。您已经准备好开始使用您的 SQL 视图了。祝您玩得开心!
额外提示¶
小技巧
SQL 视图中的一个常见错误是没有考虑到由于表连接(JOIN)导致的某些数据重复。这可能会在使用字段的 aggregator
和/或透视表视图时导致计数错误。最好使用足够的数据测试您的 SQL 视图,以确保结果字段值符合预期。
小技巧
如果您有一个字段不希望作为度量值(即在透视表或图表视图中),请为其添加 store=False
,这样它就不会显示。