加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

plsql – 将Boolean转换为Varchar2

发布时间:2020-12-12 15:13:09 所属栏目:百科 来源:网络整理
导读:我有一个示例代码,我正在尝试打印布尔值. 它导致了错误. wrong number or types of arguments in call to ‘PUT_LINE’ wrong number or types of arguments in call to ‘TO_CHAR’ DECLARE status BOOLEAN:= false; BEGIN DBMS_OUTPUT.PUT_LINE(status); D
我有一个示例代码,我正在尝试打印布尔值.
它导致了错误.

wrong number or types of arguments in call to ‘PUT_LINE’

wrong number or types of arguments in call to ‘TO_CHAR’

DECLARE
    status BOOLEAN:= false;
    BEGIN
      DBMS_OUTPUT.PUT_LINE(status);
      DBMS_OUTPUT.PUT_LINE(to_char(status));
    END;

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

为什么不可能呢?

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

他们还有其他任何转换方式吗?或者我是否必须使用IF或CASE语句来猜测状态.

看来你不能连接varchar和boolean.

定义此功能:

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;

并像这样使用它:

DBMS_OUTPUT.PUT_LINE('status'|| BOOLEAN_TO_CHAR(status));

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读