我正在尝试执行此作业:
BEGIN
DBMS_SCHEDULER.CREATE_JOB (
job_name => '"TOCBA"."MAANDELIJKS_AFBOEKING"',
job_type => 'PLSQL_BLOCK',
job_action => 'DECLARE
V_SALDO_CREDIT NUMBER;
V_SALDO_STUD NUMBER;
V_LIMIET NUMBER;
V_REKENINGNUMMER NUMBER;
V_CRED_ID NUMBER;
V_STU_ID NUMBER;
BEGIN
FOR R IN (SELECT r2.REKENINGNUMMER AS REKNUMMER FROM Rekening r1 INNER JOIN Rekening r2 ON r1.REKENINGNUMMER = R2.REKENINGNUMMER and r1.REKENINGTYPE = 22 and r2.REKENINGTYPE = 41)
LOOP
SELECT SALDO, BETAALLIMIET, REKENINGNUMMER, REKENINGID INTO V_SALDO_CREDIT, V_LIMIET, V_REKENINGNUMMER, V_CRED_ID FROM REKENING WHERE REKENINGNUMMER = R.REKNUMMER AND REKENINGTYPE = 41;
SELECT REKENINGID INTO V_STU_ID FROM REKENING WHERE REKENINGNUMMER = R.REKNUMMER AND REKENINGTYPE = 22;
V_SALDO_STUD := V_LIMIET -V_SALDO_CREDIT;
UPDATE REKENING SET SALDO = (SELECT BETAALLIMIET FROM REKENING WHERE REKENINGNUMMER = V_REKENINGNUMMER AND REKENINGTYPE = 41) WHERE REKENINGNUMMER = R.REKNUMMER AND REKENINGTYPE = 41;
UPDATE REKENING SET SALDO = SALDO - V_SALDO_STUD WHERE REKENINGNUMMER = R.REKNUMMER AND REKENINGTYPE = 22;
INSERT INTO TRANSACTIE(REKENINGID, BEDRAG, DATUM, IBAN_PARTIJ2, OMSCHRIJVING, TYPE) VALUES (V_STU_ID, V_SALDO_STUD,SYSDATE, V_CRED_ID, "Maandelijkse afboeking " || to_char(sysdate, "Month"), "MND");
INSERT INTO TRANSACTIE(REKENINGID, BEDRAG, DATUM, IBAN_PARTIJ2, OMSCHRIJVING, TYPE) VALUES (V_CRED_ID, V_SALDO_STUD,SYSDATE, V_STU_ID, "Maandelijkse afboeking " || to_char(sysdate, "Month"), "MND");
END LOOP;
END;',
number_of_arguments => 0,
start_date => TO_TIMESTAMP_TZ('2018-11-05 14:15:02.000000000 EUROPE/BERLIN','YYYY-MM-DD HH24:MI:SS.FF TZR'),
repeat_interval => 'FREQ=MINUTELY;BYDAY=MON',
end_date => NULL,
enabled => FALSE,
auto_drop => FALSE,
comments => 'geen');
DBMS_SCHEDULER.SET_ATTRIBUTE(
name => '"TOCBA"."MAANDELIJKS_AFBOEKING"',
attribute => 'store_output', value => TRUE);
DBMS_SCHEDULER.SET_ATTRIBUTE(
name => '"TOCBA"."MAANDELIJKS_AFBOEKING"',
attribute => 'logging_level', value => DBMS_SCHEDULER.LOGGING_OFF);
DBMS_SCHEDULER.enable(
name => '"TOCBA"."MAANDELIJKS_AFBOEKING"');
END;
PL / SQL代码经过测试,可以在没有Job的情况下正常运行。当我尝试像这样运行它时,出现以下错误:
"ORA-06550: Regel 20, kolom 198:
PL/SQL: ORA-00984: Kolom is hier niet toegestaan..
ORA-06550: Regel 20, kolom 4:
PL/SQL: SQL Statement ignored.
ORA-06550: Regel 22, kolom 198:
PL/SQL: ORA-00984: Kolom is hier niet toegestaan..
ORA-06550: Regel 22, kolom 4:
PL/SQL: SQL Statement ignored.
"
当我删除两个insert(TRANSACTIES)语句时,它工作正常。我猜问题是由于引号而发生的。这里有人知道如何解决这个问题吗?
答案 0 :(得分:1)
我明白了你的问题。问题在于在job_action =>
中的大单引号内使用单引号。您需要为每个单引号写两次(例如,而不是'
写''
)。它不是双引号,而是单引号两次。因此,您的插入语句将如下所示:
INSERT INTO TRANSACTIE(REKENINGID, BEDRAG, DATUM, IBAN_PARTIJ2, OMSCHRIJVING, TYPE)
VALUES (V_STU_ID, V_SALDO_STUD,SYSDATE, V_CRED_ID, ''Maandelijkse afboeking '' || to_char(sysdate, ''Month''), ''MND'');
INSERT INTO TRANSACTIE(REKENINGID, BEDRAG, DATUM, IBAN_PARTIJ2, OMSCHRIJVING, TYPE)
VALUES (V_CRED_ID, V_SALDO_STUD,SYSDATE, V_STU_ID, ''Maandelijkse afboeking '' || to_char(sysdate, ''Month''), ''MND'');
希望有帮助。
答案 1 :(得分:0)
是的,正如您在单引号中注意到的那样,请执行以下示例:
单引号用于封闭Varchar(文字)和日期值,双引号用于封闭表格,列。这就是为什么它在此处不允许使用双引号弹出错误列的原因。
DECLARE
V_SALDO_CREDIT NUMBER;
V_SALDO_STUD NUMBER;
V_LIMIET NUMBER;
V_REKENINGNUMMER NUMBER;
V_CRED_ID NUMBER;
V_STU_ID NUMBER;
BEGIN
INSERT INTO TRANSACTIE
(REKENINGID, BEDRAG, DATUM, IBAN_PARTIJ2, OMSCHRIJVING, TYPE)
VALUES
(V_STU_ID,
V_SALDO_STUD,
SYSDATE,
V_CRED_ID,
'Maandelijkse afboeking ' || to_char(sysdate, 'Month'),
'MND');
END;
答案 2 :(得分:0)
对于字符串文字,您也可以使用替代报价机制(“ Q”)
https://livesql.oracle.com/apex/livesql/file/content_CIREYU9EA54EOKQ7LAMZKRF6P.html