oracle用預存程序實現mysql的drop if exists

來源:互聯網
上載者:User

以下oralce預存程序作用類似於mysql的 drop if exists功能。

 代碼如下 複製代碼
--判斷制定表是否存在,如果存在刪除該表。
create or replace procedure proc_dropifexists(  
    p_table in varchar2  
) is  
    v_count number(10);  
begin  
   select count(*)  
   into v_count  
   from user_tables  
   where table_name = upper(p_table);  
 
   if v_count > 0 then  
      execute immediate 'drop table ' || p_table ||' purge';  
   end if;  
end proc_dropifexists;



在調用預存程序的時候出了點小問題。在PLSQL中執行以上預存程序,網上很多文章都
用     exec proc_dropifexists('表名');
或者   execute proc_dropifexists('表名');
來執行。但本人在執行以上語句的時候總是報'ora 00900' 無效語句錯誤,不知為何。

最後用:  call proc_dropifexists('表名'); 執行成功。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.