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;

本回答被提问者采纳
参考技术B 可以,你的语句在语法上没问题,但是逻辑上有问题,例如假设当a=1,b=4,c=6时,不符合条件a<>1,但是却符合b<>2 、 c<>3的条件,而你三个条件之间又是or的关系,所以说仍然能执行then后面的语句。像你这种情况,用case when 语句,或者用多个if。 参考技术C 没有问题 参考技术D 把例子贴出来,应该是你给的条件不对,多个条件肯定是没有问题的。

oracle 关于条件判断

有A,B 2张表,用1条件来从A,B中选出数据,当1条件不满足时,用2条件选出数据。
这样的SQL怎么写。

用decode函数
例如
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 后可以给多个条件不?的主要内容,如果未能解决你的问题,请参考以下文章

oracle if 语句

oracle 怎么给字段增加多个条件

oracle 关于条件判断

excel中if函数怎么用有多个条件,多个结果

在oracle sql语句里有没有if...else...的用法,请各位大侠给个例子看看,灰常感谢!!

Oracle:如何使用 if 条件在存储过程中调用存储过程