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

这是我的项目结构图:

这里写图片描述

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

这里写图片描述

然后,配置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文件,运行测试,成功!!!

*

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

SSM是指Spring+SpringMVC+MyBatis的集成开发环境。MySQL是一个关系型数据库管理系统,用于存储和管理数据。Maven是一个项目管理和构建工具,可以自动下载所需的类库和插件,并管理项目的依赖关系。Idea是一个Java集成开发环境(IDE),提供了开发、调试和部署Java代码的工具。 在SSM MySQL Maven Idea MyBatis Spring SpringMVC的集成开发环境下,我们可以通过Maven构建项目,引入相应的依赖库。Idea提供了可视化的界面,方便我们进行开发和调试工作。 首先,我们可以使用Maven来管理项目的依赖。在pom.xml文件添加相应的依赖,Maven会自动下载并引入到项目。 其次,我们可以使用Idea创建Spring项目,并配置相关的配置文件。在Idea的配置界面,我们可以设置项目的数据库连接信息和配置MyBatis的相关内容。 然后,我们可以使用MyBatis来操作MySQL数据库。在MyBatismapper文件编写SQL语句,并在Spring配置相应的bean,使其可以与数据库进行交互。 此外,我们还可以使用SpringMVC来开发Web应用。在SpringMVC,我们可以通过配置相应的请求映射和控制器来处理请求,并返回相应的结果。 最后,通过整合SpringSpringMVCMyBatis,我们可以实现业务逻辑与数据库的交互,并通过Maven进行项目构建和管理。这样,我们就可以在SSM MySQL Maven Idea MyBatis Spring SpringMVC的集成开发环境进行基于这些框架和工具的开发工作了。 总之,掌握SSM MySQL Maven Idea MyBatis Spring SpringMVC的集成开发环境,意味着我们可以利用这些强大工具和框架来进行Java开发,并能够高效地开发出优质的Web应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值