首先,目标记录是存在的

SELECT * FROM d_device_user_bind dub WHERE dub.`uid`='222222222221'

mysql IF-IFNULL和IF-ISNULL同样逻辑的运行差别

其次,

 SELECT dub.uid,dub.`device_id`,IF(IFNULL(dub.`device_id`,2)=2, 2, 1) isActivate FROM d_device_user_bind dub WHERE dub.del_flag=0 ORDER BY dub.`create_time` DESC LIMIT 8;

mysql IF-IFNULL和IF-ISNULL同样逻辑的运行差别

换一个语句:  SELECT dub.uid,dub.`device_id`,IF(dub.`device_id` IS NULL OR dub.`device_id`='', 2, 1) isActivate FROM d_device_user_bind dub WHERE dub.del_flag=0 ORDER BY dub.`create_time` DESC LIMIT 8;

mysql IF-IFNULL和IF-ISNULL同样逻辑的运行差别

再一个写法: SELECT dub.uid,dub.`device_id`,IF(ISNULL(dub.`device_id`), 2, 1) isActivate FROM d_device_user_bind dub WHERE dub.del_flag=0 ORDER BY dub.`create_time` DESC LIMIT 8;

mysql IF-IFNULL和IF-ISNULL同样逻辑的运行差别

不知道为什么会这样,也许是mysql的一个bug吧。

 

相关文章:

  • 2022-12-23
  • 2021-08-20
  • 2021-07-21
  • 2022-12-23
  • 2022-12-23
  • 2021-05-05
  • 2021-07-11
猜你喜欢
  • 2021-12-06
  • 2022-12-23
  • 2022-02-07
  • 2021-11-23
  • 2022-12-23
  • 2022-12-23
相关资源
相似解决方案