mybatis错误:Invalid bound statement (not found): com.prcsteel.peanut.dao.UserDao.selectById

spring + mybatis 配置 SqlSessionFactoryBean

<bean id="sqlSessionFactory" name="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        
        <property name="dataSource" ref="dataSource" />
        
        <property name="typeAliasesPackage" value="${mybatis.model}" />
        
        <property name="mapperLocations" value="${mybatis.mapperLocations}" />
        <property name="plugins">
            <array>
                <bean class="com.github.pagehelper.PageHelper">
                    <property name="properties" value="dialect=mysql"/>
                bean>
            array>
        property>
    bean>

代理接口dao通过MapperScanConfigurer扫描注入


    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        
        <property name="basePackage" value="com.prcsteel.peanut.dao" />
        
      
    bean>

参照网上的几点建议:
1、
mapper文件namespace和dao路径对应

2.UserDao的方法在UserMapper.xml中没有,然后执行UserDao的方法会报此

3、UserDao的方法返回值是List,而select元素没有正确配置ResultMap,或者只配置ResultType!

4、如果你确认没有以上问题,请任意修改下对应的xml文件,比如删除一个空行,保存.问题解决…

发现并无上述问题。仔细查看log,发现有这一段输出:

[DEBUG] org.mybatis.spring.SqlSessionFactoryBean.buildSqlSessionFactory - Property 'mapperLocations' was not specified or no matching resources found

SqlSessionFactoryBean 并没有加载到对应的mapper xml文件,当然执行方法的时候也就找不到dao所对应的mapper,而无法执行对应的sql,查看maven target 的classes目录下也并没有mapper的xml文件出现。

原因:mapper文件并不是放在resource中,而是在java目录,maven编译的时候并没有把xml文件编译进来。
解决:在pom文件中添加resource编译

<resources>
    <resource>
        
        <directory>src/main/javadirectory>
        <includes>
            <include>**/*include>
        includes>
        <filtering>falsefiltering>
    resource>
resources>

你可能感兴趣的:(spring)