执行表达式中的例程

正如内建的函数那样,您可通过在 SQL 和 SPL 语句中的表达式,使用 SPL 例程来执行 SPL 例程(以及来自 SPL 例程的外部例程)。表达式中使用的例程通常为函数,因为它将值返回至语句的剩余部分。

例如,您可能通过将返回值分配给变量的 LET 语句来执行函数。下图中的语句执行相同的任务。它们执行 SPL 例程内的外部函数,并将返回值分配给变量 a

图: 执行 SPL 例程内的外部函数。

LET a = area( rectv.length, rectv.width );
            
            CALL area( rectv.length, rectv.width ) RETURNING a;
            -- 这些语句是等同的
您还可从 SQL 语句执行 SPL 例程,如下图所示。假设您编写 SPL 函数 increase_by_pct,对给定的价格增加给定的百分比。在您编写 SPL 例程之后,在任何其他 SPL 例程中都可使用它。

图: 从 SQL 语句执行 SPL 例程。

CREATE FUNCTION raise_price ( num INT )
            RETURNING DECIMAL;
            
            DEFINE p DECIMAL;
            
            SELECT increase_by_pct(price, 20) INTO p
            FROM inventory WHERE prod_num = num;
            
            RETURN p;
            
            END FUNCTION;

该示例选择 inventory 的指定的行的 price 列,并使用该值作为 SPL 函数 increase_by_pct 的参数。然后,该函数返回新的 price 值,在变量中增加 20%。