溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

怎么解決ERROR中JOB執(zhí)行DDL語(yǔ)句報(bào)錯(cuò)ORA-06550

發(fā)布時(shí)間:2021-11-09 13:58:38 來(lái)源:億速云 閱讀:902 作者:iii 欄目:關(guān)系型數(shù)據(jù)庫(kù)

本篇內(nèi)容主要講解“怎么解決ERROR中JOB執(zhí)行DDL語(yǔ)句報(bào)錯(cuò)ORA-06550”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“怎么解決ERROR中JOB執(zhí)行DDL語(yǔ)句報(bào)錯(cuò)ORA-06550”吧!

一、問(wèn)題描述

       需求要通過(guò)JOB定時(shí)執(zhí)行DDL語(yǔ)句(purge recyclbin),來(lái)實(shí)現(xiàn)清空回收站。簡(jiǎn)單的問(wèn)題,由于語(yǔ)法不了解所以報(bào)錯(cuò):ORA-06550 & PLS-00103。讓我們來(lái)看一下如何在JOB中執(zhí)行DDL語(yǔ)句的正確語(yǔ)法。 

二、測(cè)試

1.建立JOB

BEGIN
    DBMS_SCHEDULER.CREATE_JOB (
            job_name => '"TEST_USER"."PURGE_RECYCLBIN_TEST"',
            job_type => 'PLSQL_BLOCK',
            job_action => 'begin
purge recyclebin;
end;
',
            number_of_arguments => 0,
            start_date => NULL,
            repeat_interval => 'FREQ=WEEKLY;BYDAY=SUN;BYHOUR=0;BYMINUTE=0;BYSECOND=0',
            end_date => NULL,
            enabled => FALSE,
            auto_drop => FALSE,
            comments => '每周清理回收站');
   
    DBMS_SCHEDULER.SET_ATTRIBUTE(
             name => '"TEST_USER"."PURGE_RECYCLBIN_TEST"',
             attribute => 'logging_level', value => DBMS_SCHEDULER.LOGGING_OFF);
      
    DBMS_SCHEDULER.enable(
             name => '"TEST_USER"."PURGE_RECYCLBIN_TEST"');
END;
/

2.執(zhí)行該JOB報(bào)錯(cuò)

BEGIN
    DBMS_SCHEDULER.RUN_JOB(job_name => '"TEST_USER"."PURGE_RECYCLBIN_TEST"', USE_CURRENT_SESSION => FALSE);
END;
報(bào)錯(cuò)信息如下:
ORA-06550: line 2, column 7:
PLS-00103: Encountered the symbol "RECYCLEBIN" when expecting one of the following:
   := . ( @ % ; result_cache
The symbol ":=" was substituted for "RECYCLEBIN" to continue.

3.修改為正確執(zhí)行方式,重點(diǎn)修改job_action內(nèi)容

BEGIN
DBMS_SCHEDULER.set_attribute( name => '"TEST_USER"."PURGE_RECYCLBIN_TEST"', attribute => 'job_action', value => 'begin
execute immediate ''purge recyclebin'';
end;
');
END;
/

4.再次執(zhí)行完成(無(wú)報(bào)錯(cuò))

BEGIN
    DBMS_SCHEDULER.RUN_JOB(job_name => '"TEST_USER"."PURGE_RECYCLBIN_TEST"', USE_CURRENT_SESSION => FALSE);
END;
/

到此,相信大家對(duì)“怎么解決ERROR中JOB執(zhí)行DDL語(yǔ)句報(bào)錯(cuò)ORA-06550”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI