我有一个示例代码,我正在尝试打印布尔值.它导致了错误.
调用'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只是忘记了这种类型的转换(它极不可能).
他们还有其他任何转换方式吗?或者我必须去IF或CASE声明猜测有什么status.
小智 16
看来你不能Concat的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;
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)
这将返回1fortrue和0for false(and nullfor null)。
| 归档时间: |
|
| 查看次数: |
23920 次 |
| 最近记录: |