事情是这样的:

在跟着网上项目,利用myBatis做增删改查时,在xml文件里添加了一个update语句之后,发现web项目的登录操作没有反应,在idea上查看报错,第一次点击登录没有反应时控制台报错内容如下:

14-Apr-2022 09:32:00.958 SEVERE [http-nio-8080-exec-5] org.apache.catalina.core.StandardWrapperValve.invoke Servlet.service() for servlet [UserController] in context with path [/crm] threw exception [Servlet execution threw an exception] with root causejava.lang.StringIndexOutOfBoundsException: String index out of range: 13at java.lang.String.charAt(String.java:658)at org.apache.ibatis.builder.ParameterExpression.trimmedStr(ParameterExpression.java:131)at org.apache.ibatis.builder.ParameterExpression.option(ParameterExpression.java:124)at org.apache.ibatis.builder.ParameterExpression.jdbcTypeOpt(ParameterExpression.java:99)at org.apache.ibatis.builder.ParameterExpression.property(ParameterExpression.java:70)at org.apache.ibatis.builder.ParameterExpression.parse(ParameterExpression.java:47)at org.apache.ibatis.builder.ParameterExpression.<init>(ParameterExpression.java:39)at org.apache.ibatis.builder.SqlSourceBuilder$ParameterMappingTokenHandler.parseParameterMapping(SqlSourceBuilder.java:128)at org.apache.ibatis.builder.SqlSourceBuilder$ParameterMappingTokenHandler.buildParameterMapping(SqlSourceBuilder.java:72)at org.apache.ibatis.builder.SqlSourceBuilder$ParameterMappingTokenHandler.handleToken(SqlSourceBuilder.java:67)at org.apache.ibatis.parsing.GenericTokenParser.parse(GenericTokenParser.java:78)at org.apache.ibatis.builder.SqlSourceBuilder.parse(SqlSourceBuilder.java:45)at org.apache.ibatis.scripting.defaults.RawSqlSource.<init>(RawSqlSource.java:46)at org.apache.ibatis.scripting.defaults.RawSqlSource.<init>(RawSqlSource.java:40)at org.apache.ibatis.scripting.xmltags.XMLScriptBuilder.parseScriptNode(XMLScriptBuilder.java:58)at org.apache.ibatis.scripting.xmltags.XMLLanguageDriver.createSqlSource(XMLLanguageDriver.java:44)at org.apache.ibatis.builder.xml.XMLStatementBuilder.parseStatementNode(XMLStatementBuilder.java:94)at org.apache.ibatis.builder.xml.XMLMapperBuilder.buildStatementFromContext(XMLMapperBuilder.java:135)at org.apache.ibatis.builder.xml.XMLMapperBuilder.buildStatementFromContext(XMLMapperBuilder.java:128)at org.apache.ibatis.builder.xml.XMLMapperBuilder.configurationElement(XMLMapperBuilder.java:118)at org.apache.ibatis.builder.xml.XMLMapperBuilder.parse(XMLMapperBuilder.java:92)at org.apache.ibatis.builder.annotation.MapperAnnotationBuilder.loadXmlResource(MapperAnnotationBuilder.java:173)at org.apache.ibatis.builder.annotation.MapperAnnotationBuilder.parse(MapperAnnotationBuilder.java:124)at org.apache.ibatis.binding.MapperRegistry.addMapper(MapperRegistry.java:72)at org.apache.ibatis.binding.MapperRegistry.addMappers(MapperRegistry.java:97)at org.apache.ibatis.binding.MapperRegistry.addMappers(MapperRegistry.java:105)at org.apache.ibatis.session.Configuration.addMappers(Configuration.java:737)at org.apache.ibatis.builder.xml.XMLConfigBuilder.mapperElement(XMLConfigBuilder.java:364)at org.apache.ibatis.builder.xml.XMLConfigBuilder.parseConfiguration(XMLConfigBuilder.java:119)at org.apache.ibatis.builder.xml.XMLConfigBuilder.parse(XMLConfigBuilder.java:99)at org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:78)at org.apache.ibatis.session.SqlSessionFactoryBuilder.build(SqlSessionFactoryBuilder.java:64)at com.bjpowernode.crm.utils.SqlSessionUtil.<clinit>(SqlSessionUtil.java:26)at com.bjpowernode.crm.settings.service.impl.UserServiceImpl.<init>(UserServiceImpl.java:21)at com.bjpowernode.crm.settings.web.controller.UserController.login(UserController.java:46)at com.bjpowernode.crm.settings.web.controller.UserController.service(UserController.java:28)at javax.servlet.http.HttpServlet.service(HttpServlet.java:729)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:230)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at com.bjpowernode.crm.web.filter.LoginFilter.doFilter(LoginFilter.java:25)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at com.bjpowernode.crm.web.filter.EncodingFilter.doFilter(EncodingFilter.java:19)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199)at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:108)at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:620)at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:349)at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:784)at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:802)at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1452)at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)at java.lang.Thread.run(Thread.java:748)

在多次点击登录之后,都会出现一致的下面报错:

java.lang.NoClassDefFoundError: Could not initialize class com.bjpowernode.crm.utils.SqlSessionUtilat com.bjpowernode.crm.settings.service.impl.UserServiceImpl.<init>(UserServiceImpl.java:21)

于是,开始查找NoClassDefFoundError错误的解决方案,结果没有收获。后来发现把update语句注释之后就可以正常运行了,问题出在 sql语法上,但是idea没有出现语法错误的报错,我的错误是这样的:

 <update id="update" >update tbl_activity setowner=#{owner},name=#{name},startDate=#{startDate},endDate=#{endDate}cost=#{cost},description=#{descri,ption}editTime=#{editTime},editBy=#{editBy}where id=#{id}</update>

可以看到,错误是,#{endDate}后面没有逗号,   #{description}后面也没有逗号,且里面也多打了逗号。但是,sql语法错误在控制台并没有提示。

当我把错误改成,只有忘记写逗号时,才会有sql语法错误的提示,即,#{endDate}后面没有逗号,   #{description}后面也没有逗号。控制台信息如下:
### The error may involve defaultParameterMap
### The error occurred while setting parameters

后来我单单把错误改成: #{descri,ption}又出现了NoClassDefFoundError的错误。

结论:在mybatis的xml文件中,赋值属性出现错误的话,控制台不会提示sql语法错误,而是NoClassDefFoundError错误

解决:传参时,一定要仔细、仔细、再仔细!

NoClassDefFoundError: Could not initialize class (sqlSession文件)相关推荐

  1. weblogic .NoClassDefFoundError: Could not initialize class sun.awt.X11Graphi

    这个是常见问题,可以通过增加Weblogic的启动参数来解决: -Djava.awt.headless=true 你可以修改 startWebLogic.sh 文件. export JAVA_OPTI ...

  2. 【ERROR】java.lang.NoClassDefFoundError: Could not initialize class sun.awt.X11.XToolkit

    tomcat 出现java.lang.NoClassDefFoundError: Could not initialize class sun.awt.X11.XToolkit运行时异常,主要原因是图 ...

  3. @Autowired注解和静态方法 NoClassDefFoundError could not initialize class 静态类

    NoClassDefFoundError could not initialize class 静态类 spring boot 静态类 java.lang.ExceptionInInitializer ...

  4. 异常:Caused by: java.lang.NoClassDefFoundError: Could not initialize class net.sf.log4jdbc.Properties

    异常:Caused by: java.lang.NoClassDefFoundError: Could not initialize class net.sf.log4jdbc.Properties ...

  5. java.lang.NoClassDefFoundError: Could not initialize class sun.awt.X11.XToolkit异常解决

    处理一个老项目时遇到这样的BUG Message javax.servlet.ServletException: java.lang.NoClassDefFoundError: Could not i ...

  6. 抛错java.lang.NoClassDefFoundError: Could not initialize class sun.awt.X11.XToolkit

    参考博客: https://blog.csdn.net/pierre_/article/details/47363985 https://blog.csdn.net/catoop/article/de ...

  7. NoClassDefFoundError: Could not initialize class:XXX

    在报错的类的静态变量(或代码块)里: private static long time = Long.parseLong(ConfigUtil.getServiceConfig("timeo ...

  8. java.lang.NoClassDefFoundError: Could not initialize class org.xnio.channels.Channels

    项目场景: 项目拉下来,能正常启动,但是调用接口就报错,看了日志发现接口调用没有问题但是响应返回出错 问题描述接口 错误信息: 2022-06-10 09:33:46.954 ERROR 8524 - ...

  9. noclassdeffounderror java,从终端运行Java文件时出现java.lang.NoClassDefFoundError

    我是Java新手.我一直在使用Eclipse测试一个简单的Java类(名为NewHelloWorld),它在控制台中运行良好.当我尝试从终端执行相同的操作时,它会正确编译(创建HelloWorld.c ...

最新文章

  1. qml学习笔记(二):可视化元素基类Item详解(上半场anchors等等)
  2. 剑指 Offer 61. 扑克牌中的顺子
  3. Web开发(一)·期末不挂之第五章·CSS盒子模型(盒子模型各属性行级元素和块级元素导航栏的实现)
  4. 异步复位同步释放_简谈同步复位和异步复位
  5. 解决pycharm中新建的工程因为运行图标等均为灰色而无法运行的问题
  6. Linux signal 编程(转载)
  7. c++基础:继承与组合!
  8. Storm处理流程, 基本参数配置
  9. 万年历单片机课程设计百度文库_单片机课程设计电子万年历设计
  10. AVI视频文件编码格式不受支持0xc00d5212怎么解决?
  11. css进阶四(多媒体嵌入)
  12. PostgreSQL AUTO INCREMENT(自动增长)
  13. 《数据库系统概论》学习总结
  14. 诸侯安置 搜索02 empire
  15. 如何选择合适的电烙铁
  16. shell脚本中命名管道
  17. WP7平衡球游戏开发教程--初识XNA Faeseer Magic
  18. 【嵌入式STM32-05】STM32 外部中断 EXTI 基本原理|库函数程序代码|寄存器
  19. Mycat之——错误处理总结
  20. Oracle之SQL优化-索引的基本原理(一)

热门文章

  1. Java实现多张图片合并成一份PDF文件
  2. 玩转这6个平台,用Python接单告别死工资,三个月挣了去年一年的收入!
  3. 用户态和内核态之间的切换
  4. MySQL 查询 limit 1000,10 和 limit 10 速度一样快吗? 深度分页如何破解
  5. python模糊匹配忽略大小写_正则表达式忽略大小写匹配,但保留特定大小写的结果...
  6. Tribon数据抽取的一些心得
  7. 廊坊特色农业 国稻种芯·中国水稻节:河北复合农业促增收
  8. java如何做一个选择英雄界面手机购买,一个手机游戏商接受了我!开始创作手机英雄坛说JAVA版!...
  9. 步态剪影_50个免费高质量剪影集
  10. Cocos2d-x的Eclipse工程中:导入91sdk后AndroidMainfest.xml报错