这是代码:
set serveroutput ON;
DECLARE
id_emp NUMBER := '&EmpleadoNumero';
n_commission DOUBLE;
BEGIN
SELECT i.id,
Decode(i.commission_pct, SUM(i.commission_pct) > 100000,
i.commission_pct + ( i.commission_pct * .10 ),
SUM(i.commission_pct) > 100000
AND SUM(i.commission_pct) < 1000000,
i.commission_pct + ( i.commission_pct * .15 ),
SUM(i.commission_pct) > 1000000,
i.commission_pct + ( i.commission_pct * .20 ),
0) N_Commission
FROM s_emp i
inner join s_ord S
ON ( i.id = S.sales_rep_id );
INTO id_emp, n_commission;
dbms_output.Put_line('El empleado numero: '
|| idemp
|| ' tiene una nueva comisión de: '
|| n_comision);
END; 当我试用它时,我得到了: ORA-06550 PLS-00103错误。
发布于 2014-08-27 07:54:43
您选择的语法是错误的,应该是
SELECT i.id,
Decode(i.commission_pct, SUM(i.commission_pct) > 100000,
i.commission_pct + ( i.commission_pct * .10 ),
SUM(i.commission_pct) > 100000
AND SUM(i.commission_pct) < 1000000,
i.commission_pct + ( i.commission_pct * .15 ),
SUM(i.commission_pct) > 1000000,
i.commission_pct + ( i.commission_pct * .20 ),
0) N_Commission
INTO id_emp, n_commission
FROM s_emp i
inner join s_ord S
ON ( i.id = S.sales_rep_id ); 请注意,into子句位于FROM子句之前,在FROM子句本身中用分号结束语句
https://stackoverflow.com/questions/25521631
复制相似问题