oracle if 后可以给多个条件不?
比如:if(a<>1orb<>2orc<>3)then...我这样写,条件不成立仍然执行了then后面的语句ifn>0thenif(a<>1orb<>2orc<>3)th...
比如: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拿到最外层好像就对了,这样写法有问题? 展开
我 这样写,条件不成立仍然执行了then后面的语句
if n>0 then
if(a<>1 or b<>2 or c<>3) then
....
end if;
else
...
end if;
这样写的,把嵌套在里面的if拿到最外层好像就对了,这样写法有问题? 展开
5个回答
展开全部
这样的语法肯定是可以的。关键是你的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公司的整个产品线包括数据库服务器、企业商务应用套件、应用开发和决策支持工具。
展开全部
这样的语法肯定是可以的。
关键是你的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么?
关键是你的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;
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
可以,你的语句在语法上没问题,但是逻辑上有问题,例如假设当a=1,b=4,c=6时,不符合条件a<>1,但是却符合b<>2 、 c<>3的条件,而你三个条件之间又是or的关系,所以说仍然能执行then后面的语句。像你这种情况,用case when 语句,或者用多个if。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
没有问题
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
把例子贴出来,应该是你给的条件不对,多个条件肯定是没有问题的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询