mysql诡异问题

select cast(demand_id as char) demand_id,cast(if(demander_id is null,'',demander_id) as char) demander_id,cast(if(service_id is null,'',service_id) as char) service_id from ido_demand_single where (demander_id=15 and service_id=30) or (demander_id=30 and service_id=15) and cancel=0



select cast(demand_id as char) demand_id,cast(if(demander_id is null,'',demander_id) as char) demander_id,cast(if(service_id is null,'',service_id) as char) service_id from ido_demand_single where ((demander_id=15 and service_id=30) or (demander_id=30 and service_id=15) )and cancel=0


以上两个sql都可以在navicat中使用查询结果一致,但在jdbc拼sql的时候发生了查询错误,经过排查发现,在mysql的jar包中执行时候

and优先于or

但在navicat中执行,or和and是同级别的,谁在前边谁优先,所以可以看出不同的mysql驱动,执行的时候也会有细微的问题出现,在此记录一下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值