
文章图片

文章图片
引言今天一大早上 , 产品经理杨姐就来找我说:“小米 , 赶紧看看群里 , 运营的童鞋说系统无论是B端还是C端 , 秒杀频道都不能打开了 , 每天都有秒杀活动 , 这事很着急啊”!好家伙 , 看来事情确实蛮严重的……
定位问题我立刻打开电脑 , 查看日志 , 发现日志中报错信息是 “SQL语句” 执行错误 , 我把sql语句捞出来放到 Navicat 上 , 并填充相应的参数 , 发现报以下错误:
分析了该sql语句 , 并把 不相关的where查询条件 干掉 , 最后把问题定位到这一行:
最终发现是 IF()函数 中 , 条件为 false 执行的语句有问题 , 即“g.goods_sub_type IN NULL” 报错!
修复问题既然发现出现问题的地方 , 就开始着手修复问题 , 看了下业务逻辑 , IN 后面的是一个固定的数组 , 所以把 IN 后面写成固定数组即可 , 像这样:
搞定!
MySQL IF()函数IF()函数在条件为TRUE时返回一个值 , 如果条件为FALSE则返回另一个值 。
语法如下:
IF(conditionvalue_if_truevalue_if_false)
注意
- IF() 函数 , 无论 condition 为 true 还是 false , 后面两个语句是一定会被运行的 , 即要保证 value_if_true 和 value_if_false 的语法是正确的 , 而不是认为 condition 为 true 的时候 , value_if_false 会移除掉 。 就像在本例中 , 开发人员错误的任务当 NULL IS NULL 的时候 ,只有 1 = 1, 而 g.goods_sub_type IN NULL 会去掉 。
- IN 语句后面的范围一定要用小括号 “()” 包裹才可以 。
- 本文转自:央广网央广网兰州12月13日消息(记者邸文炯)记者从兰州大学获悉|第四届中国研究生人工智能创新大赛圆满落幕
- 手机wifi密码忘记怎么办?教你一招!
- Java|华为笔记本双12大促开启 智慧体验让办公学习更高效
- 平时在使用wps办公软件时|如何清除wps最近打开的记录
- 大家在工作和生活中可能会遇到这样的事情|word做好表格忘记加标题怎么办?最简单实用的操作方法
- 每当换手机的时候|qq聊天记录怎么迁移到新手机上?
- 现在的手机功能越来越强大|手机长时间给手机充电怎么办?记得打开这个功能!
- 越来越多的人觉得|现在买笔记本真的没意义了吗?
- 笔记本电脑|14英寸1kg左右的,超轻薄笔记本电脑,什么款式好
- 键盘|上网笔记本电脑维修点滴—续
