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

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

时间:2024-08-26 19:21:49浏览次数:8  
标签:trim 标签 SQL 逗号 P152 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" 等。

标签:trim,标签,SQL,逗号,P152,sql,报错,文本
From: https://blog.csdn.net/Yluciud/article/details/141557765

相关文章

  • 微软常用运行库合集|dll报错必装,Visual C++ 下载安装
    前言MicrosoftVisualC++Redistributable(简称MSVC,VB/VC,系统运行库)是Windows操作系统应用程序的基础类型库组件。此版VisualC++运行库组件合集(微软常用运行库合集)由国内封装爱好者@Dreamcast打包而成,整合VisualC++组件安装包运行库所有版本,提供图形安装界面,可自选更新V......
  • AI人像换脸!Reactor插件本地部署方法(含报错解决及整合包)
    ​Reactor插件是什么?有什么用?Reactor是一个用于StableDiffusion的换脸插件,主要功能是实现图片中的精确换脸。它可以自动检测并替换图片中的多个面部,适用于多种场景,比如生成逼真的图像或者进行复杂的图片处理。通过Reactor,用户可以更轻松地实现高质量的换脸效果,提......
  • AxureRP原型图软件常见报错问题汇总
    做Axure教程有一段时间了,很多小伙伴在使用软件的时候就遇到很多问题,甚至还有在初始安装软件的时候就困难重重。这篇文章在你使用Axure软件过程中绝对可以用得到,赶紧点赞收藏起来~ 本期我们分为软件安装、和软件使用问题。本期只分享一些高频问题,如果你还遇到什么别的奇葩问题,......
  • apt update 报错:Could not handshake: Error in the pull function. [IP: 185.199.108
    sudoaptupdate报错:错误:12https://nvidia.github.io/nvidia-container-runtime/stable/ubuntu18.04/amd64ReleaseCouldnothandshake:Errorinthepullfunction.[IP:185.199.108.153443]错误:13https://nvidia.github.io/nvidia-docker/ubuntu18.04/amd64Re......
  • vue3的天气组件vue3-mini-weather为何安装会报错?
    参考于:https://gitee.com/maocaoying_admin/vue3-mini-weather安装上述地址的组件报错:实现的效果图:实现步骤:1将vue3-mini-weather的lib直接拿到自己的项目中来:2将lib中的组件引入到自己项目中使用点击查看代码<template><divclass="section-income"><div......
  • 解决typescript项目报错:找不到模块“xxx”或其相应的类型声明问题
    在TypeScript项目中遇到"找不到模块'xxx'或其相应的类型声明"的错误,通常意味着TypeScript编译器无法找到你尝试导入的模块,或者没有为该模块提供类型定义。以下是一些解决这个问题的方法:检查模块名称:确保你导入的模块名称是正确的,并且与你的文件系统中的模块名称一致。安装类......
  • Ros2 Moveit2 编译安装报错解决方案 - By not providing "Findgz_sim_vendor.cmake" i
    moveit_resources---stderr:gz_ros2_controlCMakeErroratCMakeLists.txt:27(find_package):Bynotproviding"Findgz_sim_vendor.cmake"inCMAKE_MODULE_PATHthisprojecthasaskedCMaketofindapackageconfigurationfileprovidedby"gz......
  • 使用baidu加速镜像来加速pip安装的时候报错
    系统默认配置了百度的python加速镜像,地址是:https://mirror.baidu.com/pypi/simple发现在使用的时候报错:python3-mpipinstallpip-U--userLookinginindexes:https://mirror.baidu.com/pypi/simpleRequirementalreadysatisfied:pipin/usr/local/lib/python3.1......
  • Jenkins报错
    [808]Therewereerrorscheckingtheupdatesites:SSLHandshakeException:sun.secu解决方案(1)插件管理页面提示:Therewereerrorscheckingtheupdatesites:IOException:Unabletotunnelthroughproxy.Proxyreturins“HTTP/1.1400”image(2)插件管理页面提示:Therewer......
  • QQ稳定运行秘籍:处理qbcore.dll错误,告别频繁报错
    在使用QQ时,如果遇到因qbcore.dll文件错误而导致的频繁报错问题,不必过于担心。以下是一些有效的处理方法和建议,帮助您恢复QQ的稳定运行:1.重新安装QQ应用程序qbcore.dll是QQ应用程序的一个关键动态链接库文件,负责与操作系统进行交互并支持QQ的运行。如果该文件出现错误或损坏......