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

关于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中:

这是我的项目结构图:

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

这是我的项目配置文件图:

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

然后,配置spring配置文件代码,由于我的配置文件是分开写的,所以就不方便都贴出来了:

"1.0" encoding="UTF-8"?>
"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">

    
    package="com.csmzxy.controller">


    
    

    
    "org.springframework.web.servlet.view.InternalResourceViewResolver">
        
        "prefix" value="/WEB-INF/jsp/" />
        "suffix" value=".jsp" />
    
    
    "/WEB-INF/js/" mapping="/js/**"/>
    "/WEB-INF/css/" mapping="/css/**"/>

    
    "multipartResolver"
          class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        
        "defaultEncoding" value="UTF-8">
        
        "maxUploadSize" value="5242880">
    

然后,框架整合完毕,配置文件也写完了,就自己写了个测试,通过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()方法未找到”错误:

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

自己在百度找了个遍,都说是要检查自己的mapper文件namespace空间名不对,mapper文件查询方法参数绑定错误等等,然后,自己仔细检查,绝对没有问题,重要的事情说三遍:“代码绝对没有问题!代码绝对没有问题!代码绝对没有问题!”,那么问题究竟是出在哪呢???**

问题解决方案:

由于自己对idea不够熟悉,仔细研究后发现build后的项目target文件夹下面才是项目的真实文件输出路径,细看mapper项目中target文件夹输出目录中并没有mapper.xml文件,显然问题出现在这里:mapper文件找不到,然后,查看application-dao.xml文件发现mapper自动扫描mapper文件的包路径为:

 
    "org.mybatis.spring.mapper.MapperScannerConfigurer">
        "basePackage" value="com.csmzxy.mapper" />
    

习惯用myeclipse的朋友对idea可能不太熟悉,当然,这在eclipse中不会出现任何问题,但是在idea中的文件目录分为4个级别,如图:

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

我们的xml文件要被写入tatget文件夹,就得放在resources文件夹下面才可以被当做资源加入target文件夹中,才不会报找不到mapper.xml文件错误,而由于我们的spring配置文件中的“自动扫描配置映射器“路径 如下:
java




而mapper.xml文件对应的mapper接口文件也在该包下面,所以我在项目resources文件夹下面新建一个com.csmzxy.mapper包,在该包中只放mapper.xml文件,文件就可以被当做资源和mapper接口文件写入统一文件夹中:

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

ok!大工告成,targer文件夹中可以读出mapper.xml文件,运行测试,成功!!!

*

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

你可能感兴趣的:(java-web)