3

我想将变量\参数传递到视图中以按日期范围进行过滤。由于我在视图中进行分组,因此无法将 where 子句放在视图外部。

我已经阅读了很多关于这个的帖子,但还没有让它工作。我见过的将参数传递到视图中的大多数解决方法都涉及使用函数来返回值,这就是我卡住的地方。

/* My current view that I want to pass in start and end dates */
CREATE VIEW Total_Sales_By_Product_Num AS
SELECT products_all_fields.*,
    Sum(<a bunch of code removed for this sample>) AS Item_Qty_Requested_Total, 
    Sum(<a bunch of code removed for this sample>) AS Item_Qty_Accepted_Total,  
    Sum(<a bunch of code removed for this sample>) AS Total_Sales_Dollars
FROM products_all_fields
    LEFT OUTER JOIN (web_orders_items
        INNER JOIN web_orders_header
            ON  web_orders_items.Web_Order_Num = web_orders_header.Web_Order_Num )
        ON  products_all_fields.Product_Num = web_orders_items.Product_Num
WHERE web_orders_header.Order_Date BETWEEN fn_GetStartDate() AND fn_GetEndDate()
GROUP BY products_all_fields.Product_Num
ORDER BY products_all_fields.Description

将参数返回给视图的函数:

CREATE FUNCTION fn_GetStartDate ()
    RETURNS DATE
    DETERMINISTIC NO SQL
BEGIN
    RETURN @StartDate;
END

CREATE FUNCTION fn_GetEndDate ()
    RETURNS DATE
    DETERMINISTIC NO SQL
BEGIN
    RETURN @EndDate;
END

这不起作用,它不返回任何数据,我知道我在做一些愚蠢的事情

set @fn_StartDate := '2012-01-01';
set @fn_EndDate := '2012-02-01';
select * from Total_Sales_By_Product_Num

谢谢你的帮助!

4

3 回答 3

3

啊啊啊!!!我得到了它的工作,我觉得自己像个白痴,但是在我的一个日期作业中我使用了双引号而不是单引号。它现在似乎起作用了。我会将这篇文章留给未来寻找如何做到这一点的人。

于 2013-01-24T22:23:03.947 回答
1

它应该如下工作:

set @StartDate := '2012-01-01';
set @EndDate := '2012-02-01';
select * from Total_Sales_By_Product_Num;
于 2019-07-17T13:28:17.170 回答
0

你需要

SET @fn_StartDate = fn_GetStartDate('2012-01-01')

与@fn_EndDate 相同

然后在你看来

WHERE web_orders_header.Order_Date BETWEEN @fn_StartDate.....

但是,这只是如何调用函数的语法。据我所知,您仍在尝试将参数传递给视图,这是不可能的。尝试将所有视图逻辑放在函数中。

于 2013-01-24T22:18:25.990 回答