我正在使用 PL/SQL,我想检查表中是否存在记录,我尝试使用 when exists 或 if not exists,但最终出现异常。
Select name from nameTable where name = nameFromArgument;
当程序启动时,我输入了一个错误的名称,它不在数据库中我得到一个错误,甚至无法处理它
我试过这样的事情:
编辑:
对不起,我之前放的选择只是一个例子,整个代码[对不起变量名...]在这里:
CREATE OR REPLACE
PROCEDURE SELLSTOCKS
( IloscAkcji IN NUMBER
, NazwaAkcji IN VARCHAR2
, IdRachunkuMaklerskiego IN NUMBER
) AS
Bledna_ilosc EXCEPTION;
Bledna_nazwa EXCEPTION;
amount NUMBER;
stocksCash number;
idRachunku number;
stocksOnDealerSide number;
temp number;
tempus akcje_uzytkownika.nazwa % type;
BEGIN
--Select nazwa into tempus from akcje_uzytkownika where nazwa = nazwaakcji;
--dbms_output.put_line(tempus);
dbms_output.put_line('pre');
select nazwa into tempus from akcje_uzytkownika where nazwa = nazwaakcji;
dbms_output.put_line('pre2');
if tempus!=null then
if ( iloscakcji> amount) THEN
raise Bledna_ilosc;
else
select ilosc, cena_sztuki into amount, stockscash from akcje_uzytkownika where nazwa= NazwaAkcji and id_rachunku_maklerskiego= IdRachunkuMaklerskiego;
dbms_output.put_line(amount);
dbms_output.put_line(stockscash);
amount :=amount - iloscakcji;
dbms_output.put_line(amount);
update akcje_uzytkownika set ilosc= amount where nazwa=NazwaAkcji and id_rachunku_maklerskiego= idrachunkumaklerskiego;
stockscash:= iloscAkcji * stocksCash;
dbms_output.put_line(stockscash);
select id_rachunku into idrachunku from rachunek_maklerski where id_rachunku_maklerskiego= idrachunkumaklerskiego;
temp:=SALDOUPDATE(stockscash, idrachunku);
select ilosc into stocksOnDealerSide from akcje where nazwa = nazwaAkcji;
stocksOnDealerSide := stocksondealerside+ iloscakcji;
dbms_output.put_line(stocksOnDealerSide);
update akcje set ilosc = stocksondealerside where nazwa = nazwaAkcji;
end if;
else
dbms_output.put_line('post');
end if;
EXCEPTION
when Bledna_ilosc then
dbms_output.put_line('Bledna ilosc');
when Bledna_nazwa then
dbms_output.put_line('Bledna nazwa');
END SELLSTOCKS;
我正在使用 oracle sql developer 1.5.5
BEGIN
--Select nazwa into tempus from akcje_uzytkownika where nazwa = nazwaakcji;
--dbms_output.put_line(tempus);
dbms_output.put_line('pre');
select nazwa into tempus from akcje_uzytkownika where nazwa = nazwaakcji;
dbms_output.put_line('pre2');
exception when no_data_found then
raise no_data_found;
-- is this the right place?
select ilosc, cena_sztuki into amount, stockscash from akcje_uzytkownika where nazwa= NazwaAkcji and id_rachunku_maklerskiego= IdRachunkuMaklerskiego;
dbms_output.put_line(amount);
dbms_output.put_line(stockscash);
amount :=amount - iloscakcji;
dbms_output.put_line(amount);
if ( iloscakcji> amount) THEN
raise Bledna_ilosc;
else
update akcje_uzytkownika set ilosc= amount where nazwa=NazwaAkcji and id_rachunku_maklerskiego= idrachunkumaklerskiego;
stockscash:= iloscAkcji * stocksCash;
dbms_output.put_line(stockscash);
select id_rachunku into idrachunku from rachunek_maklerski where id_rachunku_maklerskiego= idrachunkumaklerskiego;
temp:=SALDOUPDATE(stockscash, idrachunku);
...........