Oracle 按下按钮触发时引发未处理异常ORA-01400

Oracle 按下按钮触发时引发未处理异常ORA-01400,oracle,plsql,oracleforms,Oracle,Plsql,Oracleforms,我正在尝试将数据从.CSV文件导入Oracle数据库。 一旦我跑了,我就会出错 WHEN-BUTTON-PRESSED trigger raise unhandled exception ORA-01400 declare import_file text_io.file_type; export_file text_io.file_type; import_file_name varchar2(1000); export_file_name varchar2(

我正在尝试将数据从.CSV文件导入Oracle数据库。 一旦我跑了,我就会出错

WHEN-BUTTON-PRESSED trigger raise unhandled exception ORA-01400

declare 

   import_file text_io.file_type; 
   export_file text_io.file_type; 
   import_file_name varchar2(1000);
   export_file_name varchar2(1000);

   import_log_file text_io.file_type;
   import_log_file_name varchar2(1000);

  vec_importovano number;
   brojac number;
   brojac_redova number;
   linebuf varchar2(5000);

   p_rbr varchar2(10);
   p_polica varchar2(10);
   p_banka VARCHAR2(10);
   p_kontakt varchar2(10);

  kraj_fajla number;

begin
    brojac_redova:=0;

    import_file_name := :Global.Lokacija_prenosa||:import.naziv_fajla||:Global.Ekstenzija_prenosa;
    import_file := text_io.fopen(import_file_name,'r');

    delete from zivot_trajni_nalog_ponude where banka is not null;
    commit;

    kraj_fajla := 0;  
    while kraj_fajla = 0 loop
  begin     
    brojac_redova:=brojac_redova+1;
    text_io.get_line(import_file, linebuf);               

 if brojac_redova > 2 then

   p_polica:=substr(linebuf, 1, instr(linebuf,';',1,1)-1);
   --message(p_polica);
   p_kontakt:=substr(linebuf, instr(linebuf,';',1,1)+1, instr(linebuf,';',1,2) - instr(linebuf,';',1,1)-1);

/*
If it has third semicolon then use your formula, string between 2 and 3. If it has only two semicolons then use from second to the end of string.
*/

   if instr(linebuf,';',1,3) > 0 then 
            p_banka := substr(linebuf, 
                            instr(linebuf,';',1, 2) + 1, 
                            instr(linebuf,';',1,3) - instr(linebuf,';',1,2)-1);
                           -- message(p_banka);

        else
          p_banka := substr(linebuf, 
                            instr(linebuf,';',1, 2) + 1);   
                            --message(p_banka);                     
        end if;  


        insert into ZIVOT_TRAJNI_NALOG_PONUDE 
        (BROJ_POLICE,REDNI_BROJ,BROJ_PONUDE,BANKA)  
         values(
         p_polica,p_rbr,p_kontakt,p_banka);     
            commit;                   
                end if;



     EXCEPTION WHEN NO_DATA_FOUND THEN kraj_fajla := 1;         
     end;

end loop;  
     IF p_rbr IS NOT NULL THEN
   update zivot_trajni_nalog_ponude set redni_broj=rownum;
    end if;         
    text_io.fclose(import_file);
      message('Zavrseno prepisivanje fajla');

end;
在将数据插入表之前,我尝试检查p_polica是否为NULL,但这不起作用。 由于IDE中没有调试器,所以无法检查错误的来源。
有人知道哪里会出错吗?我非常感谢对ORA-01400的描述是“不能在(字符串)中插入NULL”。您没有向我们提供错误消息的全文,因此我不知道
(string)
可能是什么,但它可能是一个表名和字段名-知道哪些表和字段在这里可能很重要


我怀疑表
ZIVOT\u TRAJNI\u NALOG\u PONUDE
中有一个不允许空值的字段,并且您没有在INSERT语句中填充该字段,或者您为其提供的值为空。例如,您将
p\u rbr
的值放入
ZIVOT\u TRAJNI\u NALOG\u PONUDE.REDNI\u BROJ
,但
p\u rbr
从未给定值,因此为空。如果ZIVOT_TRAJNI_NALOG_PONUDE.REDNI_BROJ有一个NOT NULL约束,则会出现该错误。

对ORA-01400的描述是“无法将NULL插入(字符串)”。您没有向我们提供错误消息的全文,因此我不知道
(string)
可能是什么,但它可能是一个表名和字段名-知道哪些表和字段在这里可能很重要

我怀疑表
ZIVOT\u TRAJNI\u NALOG\u PONUDE
中有一个不允许空值的字段,并且您没有在INSERT语句中填充该字段,或者您为其提供的值为空。例如,您将
p\u rbr
的值放入
ZIVOT\u TRAJNI\u NALOG\u PONUDE.REDNI\u BROJ
,但
p\u rbr
从未给定值,因此为空。如果ZIVOT_TRAJNI_NALOG_PONUDE.REDNI_BROJ对它有一个NOTNULL约束,您将得到该错误