oracle if 后可以给多个条件不?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle if 后可以给多个条件不?相关的知识,希望对你有一定的参考价值。
比如:if (a<>1 or b<>2 or c<>3) then ...
我 这样写,条件不成立仍然执行了then后面的语句
if n>0 then
if(a<>1 or b<>2 or c<>3) then
....
end if;
else
...
end if;
这样写的,把嵌套在里面的if拿到最外层好像就对了,这样写法有问题?
这样的语法肯定是可以的。关键是你的or,是不是你的逻辑分析出了问题?你的这个判断,只有一种情况,会不执行then后边的情况,就是a = 1 同时 b = 2同时 c = 3的时候,否则,都执行then后边的语句。是不是你的逻辑出问题,出了a = 1 and b = 2 and c = 3,那么其他时候,都符合你这个判断。
你看看你所说的条件不成立的数据是什么,如果有困惑,可以把你指的这条数据贴出来。
Oracle系统,即是以Oracle关系数据库为数据存储和管理作为构架基础,构建出的数据库管理系统。 Oracle,世界第一个支持SQL语言的商业数据库,定位于高端工作站,以及作为服务器的小型计算机,如IBM P系列服务器、HP的Integraty服务器、Sun Fire服务器。Oracle公司的整个产品线包括数据库服务器、企业商务应用套件、应用开发和决策支持工具。
参考技术A 这样的语法肯定是可以的。关键是你的or,是不是你的逻辑分析出了问题?
你的这个判断,只有一种情况,会不执行then后边的情况,就是a = 1 同时 b = 2同时 c = 3的时候,否则,都会执行then后边的语句。
是不是你的逻辑出问题了?
出了a = 1 and b = 2 and c = 3,那么其他时候,都符合你这个判断。
你看看你所说的条件不成立的数据是什么,如果有困惑,可以把你指的这条数据贴出来。
是a = 1 and b = 2 and c = 3么?追问
就是,全都相等的时候,还是执行了后现的
追答输出一下看看呢?
在if之前,先输出看看
dbms_output.put_line('a = '||to_char(a));
dbms_output.put_line('b = '||to_char(b));
dbms_output.put_line('c = '||to_char(c));
if (a1 or b2 or c3) then
end if;
然后看看输出的值是多少?
您是不是把N > 0原来也加在里面了?是补充的那个语句就对了么?
if n>0 then
if(a1 or b2 or c3) then
....
end if;
else
...
end if;
可以写if (a1 or b 2 or c 3) and n>0 then
elsif n>0 then
else
end if;
oracle 关于条件判断
有A,B 2张表,用1条件来从A,B中选出数据,当1条件不满足时,用2条件选出数据。
这样的SQL怎么写。
例如
select decode(字段名,'条件1','值1','条件2','值2',默认值') from 表名
或者 case when
如果是在pl/sql块中
可以用 if 条件 then
else if 条件 then
end if; 参考技术A select * from A,B where 1 or 2; 参考技术B case when? 参考技术C 问题补充一下 目的不是很明确
以上是关于oracle if 后可以给多个条件不?的主要内容,如果未能解决你的问题,请参考以下文章