小程序三方平台开发: 解析小程序开发的未来趋势和机遇
1401
2022-11-01
Mybatis错误引起的程序启动卡死问题及解决
目录Mybatis错误引起的程序启动卡死解决办法原因分析Mybatis启动错误具体报错如下主要内容是说找不到接口,问题可能有两个
Mybatis错误引起的程序启动卡死
mybatis xml 错误引起的程序启动卡死(没有任何报错信息,控制台卡死)排除方法
解决办法
把日志级别提高到debug,查看日志是否有异常信息
新建一个类,继承 org.mybatis.spring.SqlSessionFactoryBean 类,重载 buildSqlSessionFactory 方法,http://捕获 NestedIOException 异常,并打印异常,如下:
public class mysqlSessionFactoryBean extends SqlSessionFactoryBean {
protected SqlSessionFactory buildSqlSessionFactory() throws IOException {
try {
return super.buildSqlSessionFactory();
} catch (NestedIOException e) {
//- XML有错误时打印异常
e.printStackTrace();
throw new NestedIOException("Failed to parse mapping resource: " + e);
}
}
}
修改 mybatis 配置文件 把org.mybatis.spring.SqlSessionFactoryBean 替换为新建的类,再次启动可以在控制台输出mybatis异常信息。
原因分析
Spring解析mapper.xml文件时,执行SqlSessionFactoryBean.buildSqlSessionFactory()到断点时,抛出的异常被spring处理,但是没有输出日志信息,
Mybatis启动错误
今天在复习mybatis的基础的时候出现了错误信息,
具体报错如下
Exception in thread "main" org.apachCdVvtOdKHe.ibatis.binding.BindingException: Type interface com.hxb.mapper.AccountMapper is not known to the MapperRegistry. at org.apache.ibatis.binding.MapperRegistry.getMapper(MapperRegistry.java:47) at org.apache.ibatis.session.Configuration.getMapper(Configuration.java:745) at org.apache.ibatis.session.defaults.DefaultSqlSession.getMapper(DefaultSqlSession.java:292) at com.hxb.test.test1.main(test1.java:22)
主要内容是说找不到接口,问题可能有两个
1、没有将mapper文件注册到resource文件中。
2、还有一种错误是mapper.xml文件中的namespace文件写错。
总结,不用写后缀的情况下用".",需要后缀的时候用/
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~