首先说一下,遇到Bug的情况:
用 mybatis 写一个一对多联表查询,xml文件写的都正确。就是一直跳 InvocationTargetException 异常。
百度了下InvocationTargetException异常:Java反射执行方法时候捕获到的异常。
其实到这就应该明白了错误所在,但是猪脑子反应迟钝阿。
解决:
其中一个表的 xml 文件没有在 mybaits-config.xml 里注册。所以java反射找不到对应的资源,才报这个异常。
之前项目基本上都在spring里配置了自动扫描xml并注册,这次碰到需要手动注册的,所以遇到了问题。
手动注册一下,问题就解决了。
一般这类问题,就是java反射找不到资源。
在确保代码无误的情况下,看下配置文件是否都配置正确,可能就是错误所在。
最后分享下spring 配置 手动扫描注册xml和手动注册的差别。
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<!-- 自动扫描mapping.xml文件 -->
<!-- 将configLocation去掉,换成mapperLocations则扫描所有xml配置文件 ,-->
<!-- 如果用configLocation,则可在Configuration.xml 一个一个加载实体配置文件.xml -->
<!-- <property name="configLocation" value="mybatis/SqlMapConfig.xml" /> -->
<property name="mapperLocations" value="classpath:com/goshop/mapper/*.xml"></property>
</bean>