在sqlplus中這兩種方法都可以使用:
exec pro_name(參數(shù)1..);
call pro_name(參數(shù)1..);
區(qū)別:
1. 但是exec是sqlplus命令,只能在sqlplus中使用;call為SQL命令,沒有限制.
2. 存儲過程沒有參數(shù)時(shí),exec可以直接跟過程名(可以省略()),但call則必須帶上().
Sql代碼
SQL> --創(chuàng)建過程插入數(shù)據(jù)
SQL> create or replace procedure pro1 is
2 begin --執(zhí)行部分
3 insert into mytest values('張三', 'mm');
4 end;
5 /
Procedure created
SQL> exec pro1;
PL/SQL procedure successfully completed
創(chuàng)新互聯(lián)是一家專業(yè)提供椒江企業(yè)網(wǎng)站建設(shè),專注與做網(wǎng)站、網(wǎng)站建設(shè)、H5高端網(wǎng)站建設(shè)、小程序制作等業(yè)務(wù)。10年已為椒江眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站制作公司優(yōu)惠進(jìn)行中。
SQL> call pro1;
call pro1
ORA-06576: 不是有效的函數(shù)或過程名
SQL> call pro1();
Method called
總結(jié):在調(diào)用過程時(shí),應(yīng)該養(yǎng)成使用call,且要帶上()的習(xí)慣。