0

我目前正在处理一个 PL/SQL 问题,我必须在一个过程中创建一个游标,该游标将为给定的项目提供适当的折扣(价格 >= 100 美元为 10%,价格 >= 10 美元为 5%)。当我必须调用该程序时,我需要显示特定订单号的订单号、客户名字、姓氏和折扣后商品的总净成本(在这种情况下,我需要显示订单号2)。我无法让它显示此信息。

到目前为止,这是我使用光标创建过程的代码。

CREATE OR REPLACE PROCEDURE ComputeOrderTotal
(no_id IN orders.o_id%TYPE,
cfirst IN customer.c_first%TYPE,
clast IN customer.c_last%TYPE,
TotalNetCost OUT orders.ordertotal%TYPE) IS

CURSOR OrderCursor IS
  SELECT order_line.inv_id, inv_price, ol_quantity, inv_price*ol_quantity AS ExtPrice,
  CASE
    WHEN inv_price*ol_quantity >= 100 THEN 0.9*(inv_price*ol_quantity)
    WHEN inv_price*ol_quantity >= 10 THEN 0.95*(inv_price*ol_quantity)
    ELSE
    inv_price*ol_quantity
    END AS NetCost
  FROM inventory, order_line, orders, customer
  WHERE orders.o_id = customer.c_id;
OrderRow OrderCursor%ROWTYPE;

BEGIN
OPEN OrderCursor;
LOOP 
  FETCH OrderCursor INTO OrderRow;
  EXIT WHEN OrderCursor%NOTFOUND;
    TotalNetCost :=TotalNetCost + OrderRow.NetCost;  

END LOOP; 


DBMS_OUTPUT.PUT_LINE('Order Number:  ' || no_id || 'First Name: ' || cfirst  || 'Last Name:  ' ||
clast || 'Total Net Cost: ' || TO_CHAR(TotalNetCost, '$0999.99'));

END;

这是我调用该过程的代码。

DECLARE
no_id orders.o_id%TYPE;
cfirst customer.c_first%TYPE;
clast customer.c_last%TYPE;
TotalNetCost orders.ordertotal%TYPE;

BEGIN
ComputeOrderTotal(2, cfirst, clast, TotalNetCost);    
END;

谢谢您的帮助!

4

2 回答 2

0

我不确定,但您的条件可能是问题,因为您的第二个条件与第一个条件相矛盾。例如 110 满足第一个条件,但它也满足第二个条件。

WHEN inv_price*ol_quantity >= 100 THEN 0.9*(inv_price*ol_quantity)
WHEN inv_price*ol_quantity >= 10 THEN 0.95*(inv_price*ol_quantity)

我建议将第二个条件更改为 <100 和 >=10

于 2013-08-05T00:35:14.303 回答
0

将此行添加到调用该过程的代码的顶部。

更改会话设置服务器输出;

于 2013-08-05T01:40:08.207 回答