将Boolean转换为Varchar2

Nar*_*iya 11 plsql oracle11g

我有一个示例代码,我正在尝试打印布尔值.它导致了错误.

调用'PUT_LINE'时参数的数量或类型错误

调用'TO_CHAR'时参数的数量或类型错误

DECLARE
    status BOOLEAN:= false;
    BEGIN
      DBMS_OUTPUT.PUT_LINE(status);
      DBMS_OUTPUT.PUT_LINE(to_char(status));
    END;
Run Code Online (Sandbox Code Playgroud)

通过错误消息,很明显布尔不能以两种方式(隐式,显式)转换为字符.

为什么不可能呢?

他们有什么具体的原因吗?或Oracle只是忘记了这种类型的转换(它极不可能).

他们还有其他任何转换方式吗?或者我必须去IFCASE声明猜测有什么status.

小智 16

看来你不能Concat的varcharboolean.

定义此功能:

CREATE OR REPLACE FUNCTION BOOLEAN_TO_CHAR(STATUS IN BOOLEAN)
RETURN VARCHAR2 IS
BEGIN
  RETURN
   CASE STATUS
     WHEN TRUE THEN 'TRUE'
     WHEN FALSE THEN 'FALSE'
     ELSE 'NULL'
   END;
END;
Run Code Online (Sandbox Code Playgroud)

并像这样使用它:

DBMS_OUTPUT.PUT_LINE('status'|| BOOLEAN_TO_CHAR(status));
Run Code Online (Sandbox Code Playgroud)


Akr*_*kro 11

作为替代,我一直在使用 SYS.DIUTIL 包的BOOL_TO_INT()功能:

DECLARE
status BOOLEAN:= false;
BEGIN
  DBMS_OUTPUT.PUT_LINE(sys.diutil.bool_to_int(status));
END;
Run Code Online (Sandbox Code Playgroud)

这将返回1fortrue0for false(and nullfor null)。