Oracle sql语句中不支持boolean类型(decode&case)
2012-08-03 19:58
465 查看
Oracle sql语句中不支持boolean类型(decode&case)
版本信息:
SQL> select * from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.1.0.7.0 - 64bit Production
PL/SQL Release 11.1.0.7.0 - Production
CORE 11.1.0.7.0 Production
TNS for Linux: Version 11.1.0.7.0 - Production
NLSRTL Version 11.1.0.7.0 - Production
假设我们现在想知道1>0是否为真:
直接查,不行!
SQL> select 1>0 from dual;
select 1>0 from dual
*
ERROR at line 1:
ORA-00923: FROM keyword not found where expected
用decode转,还是不行!
SQL> select decode(1>0,true,'true','false') from dual;
select decode(1>0,true,'true','false') from dual
*
ERROR at line 1:
ORA-00907: missing right parenthesis
用case转,依旧不行!
SQL> select case 1>0 when true then 'true' else 'false' end from dual;
select case 1>0 when true then 'true' else 'false' end from dual
*
ERROR at line 1:
ORA-00923: FROM keyword not found where expected
原因在于sql不支持boolean类型(手头没有其他库,不知道mysql和sqlserver是否支持):
SQL> create or replace function is_true return boolean
is
begin
return true;
end;
/
Function created.
SQL> select is_true from dual;
select is_true from dual
*
ERROR at line 1:
ORA-06552: PL/SQL: Statement ignored
ORA-06553: PLS-382: expression is of wrong type
直接放sql语句中行不通,试着放到fuction里:
decode还是出错:
SQL> CREATE OR REPLACE FUNCTION is1gt0
RETURN VARCHAR2
IS
BEGIN
RETURN DECODE (1 > 0, TRUE, 'true', 'false');
END;
/
Warning: Function created with compilation errors.
SQL> show err;
Errors for FUNCTION IS1GT0:
LINE/COL ERROR
-------- -----------------------------------------------------------------
5/3 PL/SQL: Statement ignored
5/10 PLS-00306: wrong number or types of arguments in call to 'DECODE'
SQL>
case完美通过:
SQL> CREATE OR REPLACE FUNCTION is1gt0
RETURN VARCHAR2
IS
BEGIN
RETURN CASE 1 > 0
WHEN TRUE
THEN 'true'
ELSE 'false'
END;
END;
/
Function created.
SQL> show err;
No errors.
SQL> select is1gt0 from dual;
IS1GT0
--------------------------------------------------------------------------------
true
SQL>
小结:
1. Oracle sql语句中不支持boolean类型;
2. decode是oracle独有的;而case是标准sql,mysql和sqlserver也可以使用,而且case还能把boolean转换输出。
REF:
1.Decode function to Oracle 7 http://www.groupsrv.com/computers/about56979.html
版本信息:
SQL> select * from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.1.0.7.0 - 64bit Production
PL/SQL Release 11.1.0.7.0 - Production
CORE 11.1.0.7.0 Production
TNS for Linux: Version 11.1.0.7.0 - Production
NLSRTL Version 11.1.0.7.0 - Production
假设我们现在想知道1>0是否为真:
直接查,不行!
SQL> select 1>0 from dual;
select 1>0 from dual
*
ERROR at line 1:
ORA-00923: FROM keyword not found where expected
用decode转,还是不行!
SQL> select decode(1>0,true,'true','false') from dual;
select decode(1>0,true,'true','false') from dual
*
ERROR at line 1:
ORA-00907: missing right parenthesis
用case转,依旧不行!
SQL> select case 1>0 when true then 'true' else 'false' end from dual;
select case 1>0 when true then 'true' else 'false' end from dual
*
ERROR at line 1:
ORA-00923: FROM keyword not found where expected
原因在于sql不支持boolean类型(手头没有其他库,不知道mysql和sqlserver是否支持):
SQL> create or replace function is_true return boolean
is
begin
return true;
end;
/
Function created.
SQL> select is_true from dual;
select is_true from dual
*
ERROR at line 1:
ORA-06552: PL/SQL: Statement ignored
ORA-06553: PLS-382: expression is of wrong type
直接放sql语句中行不通,试着放到fuction里:
decode还是出错:
SQL> CREATE OR REPLACE FUNCTION is1gt0
RETURN VARCHAR2
IS
BEGIN
RETURN DECODE (1 > 0, TRUE, 'true', 'false');
END;
/
Warning: Function created with compilation errors.
SQL> show err;
Errors for FUNCTION IS1GT0:
LINE/COL ERROR
-------- -----------------------------------------------------------------
5/3 PL/SQL: Statement ignored
5/10 PLS-00306: wrong number or types of arguments in call to 'DECODE'
SQL>
case完美通过:
SQL> CREATE OR REPLACE FUNCTION is1gt0
RETURN VARCHAR2
IS
BEGIN
RETURN CASE 1 > 0
WHEN TRUE
THEN 'true'
ELSE 'false'
END;
END;
/
Function created.
SQL> show err;
No errors.
SQL> select is1gt0 from dual;
IS1GT0
--------------------------------------------------------------------------------
true
SQL>
小结:
1. Oracle sql语句中不支持boolean类型;
2. decode是oracle独有的;而case是标准sql,mysql和sqlserver也可以使用,而且case还能把boolean转换输出。
REF:
1.Decode function to Oracle 7 http://www.groupsrv.com/computers/about56979.html
相关文章推荐
- Oracle sql语句中不支持boolean类型(decode&case)
- Oracle的sql语句中case关键字的用法 & 单双引号的使用
- Oracle的SQL语句中如何处理‘&’符号
- oracle里面如何写case语句及decode and sign 函数用法
- Oracle学习(三)--数据类型及常用sql语句
- SQL语句中的case when语法以及Oracle中的类似方法
- oracle pl/sql之sql中的case语句
- Oracle clob类型的字段作为查询条件的sql语句写法
- Oracle中使用SQL语句修改字段类型
- Oracle-Decode()函数和CASE语句的不同
- oracle sql语句根据交易类型生成统计报表...
- SQL2005 修改默认值语句不支持W3C标准,Alter column set default doesn't work in T-SQL 2005
- Oracle sql"NOT IN"语句优化,查询A表有、B表没有的数据
- sql语句判断方法case when then 还…
- oracle的使用<一>支持的数据类型
- Oracle基础——SQL语句类型
- Oracle:SQL语句--对表的操作——修改列的数据类型( 即 修改字段的数据类型)
- Oracle Decode()函数和CASE语句的比较
- Oracle中PL/SQL的CASE语句
- Oracle-18-select语句初步&SQL中用算术表达式&别名的使用&连接运算符%distinct&where子句