0
CREATE OR REPLACE PROCEDURE Proc_TEST(T_DATE DATE DEFAULT TRUNC(SYSDATE))
AS
PREV1 VARCHAR(20);
mnth VARCHAR(20);
BEGIN
SELECT TO_CHAR(TO_DATE(TRUNC(T_DATE,'MM')-1),'MON_YYYY') INTO PREV1 FROM DUAL;
FOR i IN 1 .. 3 LOOP
mnth:='PREV'||i;
DBMS_OUTPUT.PUT_LINE('op'||mnth);
DBMS_OUTPUT.PUT_LINE('op'||PREV1);
END LOOP;
END;
/
opPREV1
opSEP_2015
,而我必须让
opSEP_2015
opSEP_2015
。
请检查这两行代码:'mnth:='PREV'|| i;'和 'DBMS_OUTPUT.PUT_LINE('op'|| mnth); ',这个错误是显而易见的。 – krokodilko
我认为你将标识符(例如'PREV1'变量)与文字串值(例如''PREV'|| i')混合在一起。这将有助于了解您尝试通过此过程实现的目标。 –
嗨,Jeff,我有三个变量prev1,prev2,prev3,并试图使用for循环打印这些变量中的值。 –