需要帮助使用 plsql 创建过程

Posted

技术标签:

【中文标题】需要帮助使用 plsql 创建过程【英文标题】:Need help creating a procedure with plsql 【发布时间】:2021-03-02 23:40:22 【问题描述】:

我需要创建一个程序来计算客户拥有的汽车数量以及客户在所有这些汽车上的花费。我设法让 select 语句单独工作,但在程序中实现它让我很难过。

CREATE OR REPLACE PROCEDURE getcars (
    v_customername     IN    saleinv.custname%TYPE
    , v_totalcars    OUT   NUMBER
    , v_moneyspent   OUT   NUMBER
) AS
BEGIN
    SELECT
    sale.custname
    , COUNT(sale.carserial)
    , round(SUM(sale.carsaleprice + serv.partscost + serv.laborcost), 2)
    INTO v_customername, v_totalcars, v_moneyspent
FROM
    saleinv   sale
    FULL OUTER JOIN servinv   serv ON sale.custname = serv.custname
    WHERE sale.custname = v_customername
GROUP BY
    sale.custname;
END;
/

这是我得到的错误:

错误(6,5):PL/SQL:SQL 语句被忽略

错误 (10,10):PLS-00403:表达式“V_CUSTOMERNAME”不能用作 SELECT/FETCH 语句的 INTO 目标

错误(10,52): PL/SQL: ORA-00904: : 无效标识符

【问题讨论】:

【参考方案1】:

只是不要进入v_customername。这是一个IN 参数。并且sale.custname 不能与输入的值不同,因为WHERE 子句无论如何都需要sale.custname = v_customername

...
SELECT count(sale.carserial),
       round(sum(sale.carsaleprice + serv.partscost + serv.laborcost), 2)
       INTO v_totalcars,
            v_moneyspent
       FROM ...
...

【讨论】:

非常感谢!现在很有意义:)

以上是关于需要帮助使用 plsql 创建过程的主要内容,如果未能解决你的问题,请参考以下文章

如何使用动态用户输入在 plsql 中使用函数/过程创建表

oracle学习1 基于oracle数据库的PLSQL编程以及存储过程的创建和使用视频

PLSQL 创建一个从其他方案调用过程和函数的包

我用plsql创建的存储过程为啥是无效的?

需要帮助在游标 PLSQL 中运行 2 个查询

PLSQL创建Oracle定时任务