关于IDEA中maven整合mybatis+spring+springMVC项目中mapper文件找不到问题的解决方案(org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.csmzxy.mapper.StudentMapper.selectByPrimaryKey)
问题出现:
最近在做一个项目,项目是基于idea工具开发,整合了mybatis,spring,springMVC三大框架,由于以前在myeclise中搭建过,故将myeclipse中mavne项目整合文件放在了idea中:
这是我的项目结构图:
这是我的项目配置文件图:
然后,配置spring配置文件代码,由于我的配置文件是分开写的,所以就不方便都贴出来了:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 配置自动扫描注解的包名 -->
<context:component-scan base-package="com.csmzxy.controller"></context:component-scan>
<!-- 配置注解驱动,开启对xml,json的读写支持 -->
<mvc:annotation-driven></mvc:annotation-driven>
<!-- 视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 设置前缀 --><!--设置前缀和后缀后 return 只需要返回(该文件夹下的文件名,无后缀名) -->
<property name="prefix" value="/WEB-INF/jsp/" />
<property name="suffix" value=".jsp" />
</bean>
<!--配置静态资源的访问映射,此配置的文件将不会被前端控制器拦截-->
<mvc:resources location="/WEB-INF/js/" mapping="/js/**"/>
<mvc:resources location="/WEB-INF/css/" mapping="/css/**"/>
<!-- 定义文件上传解析器 -->
<bean id="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 设定默认编码 -->
<property name="defaultEncoding" value="UTF-8"></property>
<!-- 设定文件上传的最大值5MB,5*1024*1024 -->
<property name="maxUploadSize" value="5242880"></property>
</bean>
</beans>
然后,框架整合完毕,配置文件也写完了,就自己写了个测试,通过application对象获取bean,然后查询下数据表数据打印出来:
ApplicationContext applicationContext=new ClassPathXmlApplicationContext("classpath:/spring/applicationContext-*.xml");
FindUser sysUserMapper = (FindUser) applicationContext.getBean("findUserImpl");
SysUser sysUser=sysUserMapper.selectByPrimaryKey(1);
System.out.println(sysUser.getUserName());
然后,测试也写完了,问题出来了,怎么查都查不到数据库数据,报“selectByPrimaryKey()方法未找到”错误:
自己在百度找了个遍,都说是要检查自己的mapper文件namespace空间名不对,mapper文件查询方法参数绑定错误等等,然后,自己仔细检查,绝对没有问题,重要的事情说三遍:“代码绝对没有问题!代码绝对没有问题!代码绝对没有问题!”,那么问题究竟是出在哪呢???**:
问题解决方案:
由于自己对idea不够熟悉,仔细研究后发现build后的项目target文件夹下面才是项目的真实文件输出路径,细看mapper项目中target文件夹输出目录中并没有mapper.xml文件,显然问题出现在这里:mapper文件找不到,然后,查看application-dao.xml文件发现mapper自动扫描mapper文件的包路径为:
<!--自动扫描配置映射器-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.csmzxy.mapper" />
</bean>
习惯用myeclipse的朋友对idea可能不太熟悉,当然,这在eclipse中不会出现任何问题,但是在idea中的文件目录分为4个级别,如图:
我们的xml文件要被写入tatget文件夹,就得放在resources文件夹下面才可以被当做资源加入target文件夹中,才不会报找不到mapper.xml文件错误,而由于我们的spring配置文件中的“自动扫描配置映射器“路径 如下:
java
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.csmzxy.mapper" />
</bean>
而mapper.xml文件对应的mapper接口文件也在该包下面,所以我在项目resources文件夹下面新建一个com.csmzxy.mapper包,在该包中只放mapper.xml文件,文件就可以被当做资源和mapper接口文件写入统一文件夹中:
ok!大工告成,targer文件夹中可以读出mapper.xml文件,运行测试,成功!!!
*
任何坑,都是自己挖的!!!