关于IDEA中maven整合mybatis+spring+springMVC项目中mapper文件找不到问题的解决方案(org.apache.ibatis.binding.BindingExcepti

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_32352825/article/details/78946391

关于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文件,运行测试,成功!!!

*

任何坑,都是自己挖的!!!

猜你喜欢

转载自blog.csdn.net/qq_32352825/article/details/78946391