Thursday, January 30, 2014

The BOOLEAN Datatype


The Oracle database does not have the BOOLEAN datatype. No direct way to represent that a column like IS_ACTIVE on table ITEMS is TRUE or FALSE.
The good news is that there are simple workarounds to the situation.

How to simulate a BOOLEAN-valued column in a table?

The most popular way is to create the table with a CHAR(1) column, on which a check constraint is placed.
SQL> create table items
  2  (  item_no number(3),
  3     isactive char(1) check (isactive in ('Y','N'))
  4  );

Table created.

SQL>
SQL> insert into items
  2  values (101, 'Y');

1 row created.

SQL>
SQL> insert into items
  2  values (101, 'X');
insert into items
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.SYS_C0012084) viola


SQL>
SQL> insert into items
  2  values (101, 'N');

1 row created.
A better way is to use a NUMBER(1) column, and use 0/1 to stand for FALSE/TRUE. I call it better, as NUMBER(1) is not language-dependent. Y/N presupposes that the language in use is English. Numbers make no such assumptions.

BOOLEANs exist in PL/SQL!

Interestingly, PL/SQL does have a boolean datatype. A boolean PL/SQL variable can take the values TRUE, FALSE or NULL. It is a pity that this handy PL/SQL variable cannot be made use of conveniently in SQL. You cannot insert the PL/SQL boolean value into a table column, or fetch from a table column into a PL/SQL boolean variable.
An example of using this datatype in a PL/SQL procedure:
SQL> create or replace procedure chkequal
  2  ( a number
  3  , b number)
  4  as
  5    isequal boolean;
  6  begin
  7    isequal := (a = b);
  8    if (isequal) then
  9      dbms_output.put_line('Input values are equal');
 10    else
 11      dbms_output.put_line('Input values not equal')
 12    end if;
 13  end;
 14  /

Procedure created.

SQL> exec chkequal (3,3);
Input values are equal

PL/SQL procedure successfully completed.

SQL> exec chkequal (3,4);
Input values not equal

PL/SQL procedure successfully completed.

Summary

  • Oracle does not have a BOOLEAN datatype.
  • A NUMBER(1) column with a check constraint to allow values 0 or 1 is a good alternative for the BOOLEAN datatype. CHAR(1) or VARCHAR(1) are fine too, but they are not language-independent.
  • PL/SQL has a BOOLEAN datatype, but you cannot insert this value directly into a table or fetch from a table column directly into a PL/SQL boolean variable.

No comments:

Post a Comment