• 135456

    文章

  • 827

    评论

  • 13

    友链

  • 最近新加了换肤功能,大家多来逛逛吧~~~~
  • 喜欢这个网站的朋友可以加一下QQ群,我们一起交流技术。

MyBatis异常 之 Mapped Statements collection does not contain value for xxx

2年想跳槽阿里,大咖揭秘大厂面试的那些事儿 >>

背景

执行mybatis mapper中的一个方法时报错:

java.lang.IllegalArgumentException: Mapped Statements collection does not contain value for com.xxx.mapper.SysDictionaryMapper.findByTypeCode
	org.apache.ibatis.session.Configuration$StrictMap.get(Configuration.java:672)
	org.apache.ibatis.session.Configuration.getMappedStatement(Configuration.java:507)
	org.apache.ibatis.session.Configuration.getMappedStatement(Configuration.java:500)
	org.apache.ibatis.binding.MapperMethod.setupCommandType(MapperMethod.java:240)

分析

查看SysDictionaryMapper.findByTypeCode是否存在:

	SysDictionaryMapper.java
		List<SysDictionaryDO> findByTypeCode(@Param("typeCode") String typeCode);

	SysDictionaryMapper.xml
		<select id="findByTypeCode" resultMap="BaseResultMap">
			SELECT <include refid="baseColumn"/>
			FROM <include refid="tableName"/>
			WHERE type_code = #{typeCode} and del_status = 0
			ORDER BY sort
		</select>

查看配置:

	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource" />
		<property name="configLocation" value="classpath:mybatis-config.xml" />
		<property name="mapperLocations" value="classpath:mapper/*Mapper.xml" />
		<property name="plugins">
			<array>
				<bean class="com.xxx.interceptor.MapInterceptor"/>
				<bean class="com.xxx.interceptor.ParamterInterceptor"/>
			</array>
		</property>
	</bean>

通过分析发现,SysDictionaryMapper.xml并不是在mapper目录下,而是在其子目录下,所以导致找不到该mapper文件;

解决方案

修改配置

<property name="mapperLocations" value="classpath:mapper/**/*Mapper.xml" />

mapper/**/*Mapper.xml表示包含目录及其子目录下的所有mapper文件


695856371Web网页设计师②群 | 喜欢本站的朋友可以收藏本站,或者加入我们大家一起来交流技术!

0条评论

Loading...


发表评论

电子邮件地址不会被公开。 必填项已用*标注

自定义皮肤 主体内容背景
打开支付宝扫码付款购买视频教程
遇到问题联系客服QQ:419400980
注册梁钟霖个人博客