该异常的最后一句,通过翻译,大概是: [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注意事项
注意事项
-
条件表达式:
- 确保每个
<if>
语句中的条件表达式正确。 - 特别注意
image != null and image != ''
中的条件,确保没有多余的空格。
- 确保每个
-
去除多余的逗号:
- 当条件不满足时,多余的逗号可能会导致 SQL 语法错误。可以通过使用 MyBatis 动态 SQL 的
<trim>
标签来避免这种情况
- 当条件不满足时,多余的逗号可能会导致 SQL 语法错误。可以通过使用 MyBatis 动态 SQL 的
附:
<trim>
标签的基本语法
1<trim prefix="prefixText" prefixOverrides="overrideText" suffix="suffixText" suffixOverrides="overrideText">
2 <!-- 动态 SQL 内容 -->
3</trim>
参数说明
-
prefix
:- 含义: 指定要添加到动态 SQL 开头的文本。
- 示例:
prefix="WHERE"
-
prefixOverrides
:- 含义: 指定哪些文本会被
prefix
文本覆盖。 - 示例:
prefixOverrides=","
表示如果动态 SQL 以逗号开始,逗号会被prefix
文本替换。 - 常见值:
","
,"AND"
,"OR"
等。
- 含义: 指定哪些文本会被
-
suffix
:- 含义: 指定要添加到动态 SQL 结尾的文本。
- 示例:
suffix="LIMIT 10"
-
suffixOverrides
:- 含义: 指定哪些文本会被
suffix
文本覆盖。 - 示例:
suffixOverrides=","
表示如果动态 SQL 以逗号结束,逗号会被suffix
文本替换。 - 常见值:
","
,"AND"
,"OR"
等。
- 含义: 指定哪些文本会被