sql >> Databasteknik >  >> RDS >> Oracle

Utvärdering av PL/SQL booleska variabler i Oracle Forms

Vi kan testa detta i SQLPlus för att se vad som händer i var och en av de tre situationerna (true, false, null):

set serveroutput on

declare
  true_value boolean := true;
  false_value boolean := false;
  null_value boolean;
begin

    if not true_value then  --Should not pass
      dbms_output.put_line('True Value');
    end if;

    if not false_value then --Should pass
      dbms_output.put_line('False Value');
    end if;

    if null_value is null then --Just to make sure it is null
      dbms_output.put_line('Null Value is Null');
    end if;

    if not null_value then --Should not pass
      dbms_output.put_line('Null Value');
    end if;
end;
/

Som producerar:

SQL> set serveroutput on
SQL>
SQL> declare
  2    true_value boolean := true;
  3    false_value boolean := false;
  4    null_value boolean;
  5  begin
  6
  7      if not true_value then  --Should not pass
  8        dbms_output.put_line('True Value');
  9      end if;
 10
 11      if not false_value then --Should pass
 12        dbms_output.put_line('False Value');
 13      end if;
 14
 15      if null_value is null then --Just to make sure it is null
 16        dbms_output.put_line('Null Value is Null');
 17      end if;
 18
 19      if not null_value then --Should not pass
 20        dbms_output.put_line('Null Value');
 21      end if;
 22  end;
 23  /
False Value
Null Value is Null

PL/SQL procedure successfully completed.

SQL>

Så den enda möjliga kodsökvägen som kan producera din förväntade utdata är om värdet som går in i villkoret är falskt. Om det inte är vad du ser eller förväntar dig måste något annat hända i din procedur eller som en bieffekt.



  1. Hur gör man webbsidor med Java?

  2. Gruppera utdata från VISA KOLUMNER i en kommaavgränsad lista

  3. Körs markörer i Django i den öppna transaktionen?

  4. BESTÄLL MED samma värde i MySQL