Request processing failed:MyBatisSystemException 黑马web开发课程P152中可能出现的报错解决法案 :使用<trim>标签避免动态sql中多余的逗号

该异常的最后一句,通过翻译,大概是:     [dispatcherServlet]: servlet .service() for servlet [dispatcherServlet]在路径[]的上下文中抛出异常[请求处理失败:MyBatisSystemException]      

经过对代码的检查,发现controller,sevice,dao层业务逻辑都没有问题

dao层的mapper接口采用的是xml映射文件配置,怀疑是xml文件中的sql代码存在问题

源代码如下,是根据黑马课程编写的,对照课程代码丝毫不差,但依旧报错

经过排查,添加<trim>标签,修改代码如下,运行正常

         注:该标签的具体使用方法及参数含义附在文章结尾处 

报错原因分析:是由于在数据处理时,sql语句出现多余逗号引起的报错。

        但是在黑马课程的讲解中,使用<set>标签就可以避免这个问题,但毕竟时一年之前的课程了,大概时有了新的更新,导致原有的方法不适用了。在目前的代码中,采取<trim>标签来避免多余逗号的问题。

        回过头看这句报错 [dispatcherServlet]: servlet .service() for servlet [dispatcherServlet]在路径[]的上下文中抛出异常[请求处理失败:MyBatisSystemException]

        最后几个单词写的是:MyBatisSystemException,大概是指mybatis系统抛出的异常,也就是 说是用mybatis操作数据库时发生错误,所以很可能是sql代码有问题。以后遇到这个报错,可以主要去检查一下sql语句,已经xml文件配置等有关mybatis层的代码是否有问题。

总结:动态sql注意事项

注意事项

  1. 条件表达式

    • 确保每个 <if> 语句中的条件表达式正确。
    • 特别注意 image != null and image != '' 中的条件,确保没有多余的空格。
  2. 去除多余的逗号

    • 当条件不满足时,多余的逗号可能会导致 SQL 语法错误。可以通过使用 MyBatis 动态 SQL 的 <trim> 标签来避免这种情况

附:

<trim> 标签的基本语法

1<trim prefix="prefixText" prefixOverrides="overrideText" suffix="suffixText" suffixOverrides="overrideText">
2    <!-- 动态 SQL 内容 -->
3</trim>

参数说明

  1. prefix:

    • 含义: 指定要添加到动态 SQL 开头的文本。
    • 示例prefix="WHERE"
  2. prefixOverrides:

    • 含义: 指定哪些文本会被 prefix 文本覆盖。
    • 示例prefixOverrides="," 表示如果动态 SQL 以逗号开始,逗号会被 prefix 文本替换。
    • 常见值",""AND""OR" 等。
  3. suffix:

    • 含义: 指定要添加到动态 SQL 结尾的文本。
    • 示例suffix="LIMIT 10"
  4. suffixOverrides:

    • 含义: 指定哪些文本会被 suffix 文本覆盖。
    • 示例suffixOverrides="," 表示如果动态 SQL 以逗号结束,逗号会被 suffix 文本替换。
    • 常见值",""AND""OR" 等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值