我不断收到此错误,我无法弄清楚出了什么问题

时间:2018-06-25 02:05:11

标签: oracle plsql

ORA-01422:精确提取返回的行数超过了请求的行数  ORA-06512:第19行  01422. 00000-“精确提取返回的行数超过了请求的行数” *原因:精确提取中指定的数字小于返回的行。

*操作:重写查询或更改请求的行数


这是我的代码。它总是给我同样的问题,我也不知道如何解决。有人帮我。

VARIABLE b_colacion NUMBER;
VARIABLE b_locomocion NUMBER;

EXECUTE  :b_colacion := 8000;
EXECUTE  :b_locomocion := 12000;

DECLARE
v_min_ven NUMBER;
v_max_ven NUMBER;
v_id_vendedor NUMBER;
v_sueldo_base NUMBER;
v_annos_contratado NUMBER(2);
v_valor_asig_annos NUMBER(8):=0;

BEGIN

SELECT MIN(id_vendedor) , MAX(id_vendedor) 
INTO v_min_ven , v_max_ven 
FROM vendedor;

WHILE v_min_ven <= v_max_ven

 LOOP

SELECT id_vendedor , sueldo_base , TO_CHAR(SYSDATE , 'YYYY') - TO_CHAR(fecha_contrato , 'YYYY')
INTO v_id_vendedor , v_sueldo_base , v_annos_contratado
FROM vendedor
ORDER BY id_vendedor ASC;


IF v_annos_contratado > 0 THEN
SELECT ROUND(v_sueldo_base * (porc_asignado_contr/100))
INTO v_valor_asig_annos
FROM porc_bonif_annos_contrato
WHERE v_annos_contratado BETWEEN annos_inf AND annos_sup;

END IF;

 INSERT INTO HABERES_CALCULADOSOS 
 VALUES(v_min_ven , :b_colacion , :b_locomocion , v_valor_asig_annos);


 COMMIT;

 END LOOP;

END;

1 个答案:

答案 0 :(得分:2)

错误消息-完全提取返回的行数超过了请求的行数

这意味着-您正试图将多行保存到一个变量中。

例如-SELECT id_vendedor , sueldo_base , TO_CHAR(SYSDATE , 'YYYY') - TO_CHAR(fecha_contrato , 'YYYY') INTO v_id_vendedor , v_sueldo_base , v_annos_contratado FROM vendedor ORDER BY id_vendedor ASC;将返回 N 行数,其中N =表中的记录数-供应商

要更好地理解错误消息,您可以执行以下代码,以帮助您调试问题。

VARIABLE b_colacion NUMBER;
VARIABLE b_locomocion NUMBER;

EXECUTE  :b_colacion := 8000;
EXECUTE  :b_locomocion := 12000;

DECLARE
    v_min_ven NUMBER;
    v_max_ven NUMBER;
    v_id_vendedor NUMBER;
    v_sueldo_base NUMBER;
    v_annos_contratado NUMBER(2);
    v_valor_asig_annos NUMBER(8):=0;

BEGIN

    BEGIN
        SELECT MIN(id_vendedor) , MAX(id_vendedor) 
        INTO v_min_ven , v_max_ven 
        FROM vendedor;
    EXCEPTION
    WHEN OTHERS THEN
        DBMS_OUTPUT.PUT_LINE('Exception in the above Select Statment : ' || SQLERRM);
    END;

    WHILE v_min_ven <= v_max_ven

     LOOP
        BEGIN
            SELECT id_vendedor , sueldo_base , TO_CHAR(SYSDATE , 'YYYY') - TO_CHAR(fecha_contrato , 'YYYY')
            INTO v_id_vendedor , v_sueldo_base , v_annos_contratado
            FROM vendedor
            ORDER BY id_vendedor ASC;
        EXCEPTION
        WHEN OTHERS THEN
            DBMS_OUTPUT.PUT_LINE('Exception in the above Select Statement : ' || SQLERRM);
        END;

        IF v_annos_contratado > 0 THEN
            BEGIN
                SELECT ROUND(v_sueldo_base * (porc_asignado_contr/100))
                INTO v_valor_asig_annos
                FROM porc_bonif_annos_contrato
                WHERE v_annos_contratado BETWEEN annos_inf AND annos_sup;
            EXCEPTION
            WHEN OTHERS THEN
                DBMS_OUTPUT.PUT_LINE('Exception in the above Select Statement : ' || SQLERRM);
            END;
        END IF;

        INSERT INTO HABERES_CALCULADOSOS 
        VALUES(v_min_ven , :b_colacion , :b_locomocion , v_valor_asig_annos);
        COMMIT;

    END LOOP;
END;

您要捕获的异常是-WHEN TOO_MANY_ROWS THEN

仅告诉您,WHEN OTHERS是捕获异常的简便方法,但是在生产代码中使用不是好事:)