我有一个相当复杂的查询,我的PostgreSQL数据库通过一系列嵌套的子查询跨越4个表。然而,尽管有些微妙的外观和设置,最终它将基于两个外部参数(两个字符串需要与不同表中的字段匹配)返回两列(来自同一个表,如果这有助于情况)。我对PostgreSQL的数据库设计相当新,所以我知道这个看似神奇的东西叫视图存在,似乎它可以帮助我在这里,但也许不是。
有一些方法,我可以移动我的复杂查询在一个视图,不知何故只是传递它我需要匹配的两个值?这将大大简化我的前端代码(通过将复杂性移到数据库结构)。我可以创建一个视图,它包装我的静态示例查询,并且工作正常,但是只适用于一对字符串值。我需要能够使用它与各种不同的价值观。
因此我的问题是:是否可能传递参数到一个否则静态视图,并使其成为“动态”?或者一个视图不是正确的方法。如果还有其他东西会更好,我都耳朵!
*编辑:*根据评论中的要求,这是我的查询,因为它现在:
SELECT param_label, param_graphics_label
FROM parameters
WHERE param_id IN
(SELECT param_id
FROM parameter_links
WHERE region_id =
(SELECT region_id
FROM regions
WHERE region_label = '%PARAMETER 1%' AND model_id =
(SELECT model_id FROM models WHERE model_label = '%PARAMETER 2%')
)
) AND active = 'TRUE'
ORDER BY param_graphics_label;
参数由上面的百分比符号表示。