mysql or 短路_MySQL是否使IF()函数短路?

答案是肯定的.

mysql查询中的IF(cond,expr_true,expr_false)被短路.

这是一个测试,使用@variables来证明这一事实:

SET @var:=5;

SELECT IF(1 = 0, (@var:=@var + 1), @var ); -- using ':=' operator to modify 'true' expr @var

SELECT IF(1 = 1, @var, (@var:=@var + 1) ); -- using ':=' operator to modify 'false' expr @var

SELECT @var;

所有三个SELECT查询的结果都是“5”.

如果IF()函数没有短路,结果将是SELECT#1的’5’和SELECT#2的’6′,以及最后一个’select @var’的’7′.

这是因为在选择#1中,’true’表达式永远不会被执行,并且也不是为select#2执行的false表达式.

注意’:=’运算符用于在SQL查询(select,from和where子句)中修改@var.你可以从中获得一些非常奇特/复杂的SQL.我使用@vars在SQL查询中应用’程序’逻辑.

– J Jorgenson –

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值