weixin_42609449 2023-03-24 15:58 采纳率: 66.7%
浏览 66
已结题

mysql中使用when case语句

Mysql8.0.32
使用 when case 语句 根据不同的判断条件 给某一列赋不同的值,代码如下

update als set 存在问题=case

when instr(名称,"-ZD-ONU")=0 and isnull(名称)=0 and isnull(上联POS)=0 and isnull(所属地市)=0 and isnull(所属区县)=0 and isnull(所属 OLT)=0 and isnull(所属PON口)=0 and isnull(设备IP地址)=0 then "命名不规范"

when instr(名称,"-ZD-ONU")=0 and (isnull(名称)=1 and isnull(上联POS)=1 and isnull(所属地市)=1 and isnull(所属区县)=1 and isnull(所 属OLT)=1 and isnull(所属PON口)=1 and isnull(设备IP地址)=1) then "命名不规范,缺失数据"

when instr(名称,"-ZD-ONU")>0 and (isnull(名称)=1 and isnull(上联POS)=1 and isnull(所属地市)=1 and isnull(所属区县)=1 and isnull(所 属OLT)=1 and isnull(所属PON口)=1 and isnull(设备IP地址)=1) then "缺失数据"

else ""
end;

als表中有8万条数据,执行上述语句后更新了1万多条,但是查看更新的值,发现全部都是"命名不规范",也就是第一个条件返回的结果,但实际情况不是这样的,实际的命名不规范的很少,缺失数据的很多。
这个问题要怎么解决呢?

  • 写回答

2条回答 默认 最新

  • 文盲老顾 WEB应用领新星创作者 2023-03-24 16:13
    关注

    你都已经 instr 判断了,后边再有 isnull(名称) 没有意义

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月1日
  • 已采纳回答 3月24日
  • 创建了问题 3月24日

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?