将“WHERE”参数传递到PostgreSQL视图?

前端之家收集整理的这篇文章主要介绍了将“WHERE”参数传递到PostgreSQL视图?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个相当复杂的查询,我的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;

参数由上面的百分比符号表示。

你可以使用set returns函数
create or replace function label_params(parm1 text,parm2 text)
  returns table (param_label text,param_graphics_label text)
as
$body$
  select ...
  WHERE region_label = $1 
     AND model_id = (SELECT model_id FROM models WHERE model_label = $2)
  ....
$body$
language sql;

然后你可以做:

select *
from label_params('foo','bar')

Btw:你确定你想要:

AND model_id = (SELECT model_id FROM models WHERE model_label = $2)

如果model_label不是唯一的(或主键),那么这将最终抛出一个错误。你可能想要:

AND model_id IN (SELECT model_id FROM models WHERE model_label = $2)

猜你在找的Postgre SQL相关文章