ssm项目dao层方法异常:org.apache.ibatis.binding.BindingException: Invalid bound statement

不想你离开。 提交于 2020-04-01 19:43:16

在IntelliJ IDEA中用ssm框架搭建了一个demo项目,在执行到dao层方法时抛出这个异常:

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): cn.monolog.diana.dao.StatisticsDao.clear

 

第一反应是mapper的名称空间没有跟dao关联,或者dao的方法名和mapper的id不匹配。但是检查了一遍,没有这个问题。然后发现target目录下面并没有编译后的mapper文件。在网上搜了一下,有大神建议在pom文件的<build><resources></resources></build>标签下,将mapper的路径添加进去。类似于这样:

<resource>
    <directory>src/main/java</directory>
    <includes>
        <include>**/*.xml</include>
    </includes>
</resource>

大概思路就是编译的时候告诉maven哪些是配置文件。

 

另外还有一种方式,因为我的pom文件本来是这样的:

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    ...

    <!--项目搭建-->
    <build>
        <!--打包用名-->
        <finalName>diana.web</finalName>
        <!--插件-->
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
            </plugin>
        </plugins>
        <!--配置文件-->
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <filtering>true</filtering>
            </resource>
        </resources>
    </build>
</project>

即已经指定了配置文件的位置:src/main/resources,那么我把mapper文件扔到resources目录下(而不是java目录下)就可以了,类似于这样:

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!