• 解决mybatis case when 报错的问题


    fe842ae41263b93833740371aac75ba6.png

    在mybatis中使用case when进行条件筛选判断时遇到

    Failed to process, please exclude the tableName or statementId.

    这样的报错信息,报错的信息是语法错误

    但是我在mysql的命令行中运行sql语句是没问题的

    //我的case when语句

    WHERE dept.type = 1

    AND

    (

    CASE agent.dept_type

    WHEN “agent” THEN dept.id=30

    END

    )

    //当agent的dept_type为"agent"时,将添加dept.id = 30的判断

    这段sql语句在命令行内运行没问题但是放到mybatis上执行就会报错

    //修改后

    WHERE dept.type = 1

    AND dept.id=

    (

    CASE agent.dept_type

    WHEN “agent” THEN 30

    END

    )

    后来将dept.id放到外面就解决了这个问题

    20190718-补充记录 :遇到另一个问题,如果dept这个表是联查来的有可能会没有数据,在dept无数据的时候我们就无法给dept.id赋上啥参数了,并且不可以影响原表数据的查询,我改成了下面这样:

    //修改后

    WHERE dept.type = 1

    AND (dept.id=

    (

    CASE agent.dept_type

    WHEN “agent” THEN 30

    ELSE 0

    END

    ) or dept.id is null)

    添加dept.id为空的判断即可

    (在mysql语句里可以有很多方法解决,但是在mybatis上就会报错 -_-||)

    2019-7-30-补充说明:

    如果是空字符串不可以使用"“要改成单引号”"

    CASE WHEN *** THEN ***

    ELSE “” =>这样也会报错,需要改成=> ELSE""

    补充:Mybatis case when test 注意事项

    p_id areaId,

    c_id areaId,

    r_id areaId,

    test 中 用 == 不能用 = ,否则报错。

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持云海天教程。如有错误或未考虑完全的地方,望不吝赐教。

  • 相关阅读:
    经典目标检测神经网络 - RCNN、SSD、YOLO
    Linux环境部署应用必知必会
    pom的配置策略
    Mysql 的安装
    大数据学习-Hive
    为什么MySQL的浮点数类型不够精准?(实例证明)
    java8到java17的主要新增语法特性
    主语补足语SC【语法笔记】
    Radis缓存异常以及处理方案(雪崩击穿穿透预热降级)
    Ae 效果:CC Bubbles
  • 原文地址:https://blog.csdn.net/m0_67393828/article/details/126616648