leopard1214
leopard1214
2021-01-22 02:07
采纳率: 66.7%
浏览 71
已采纳

mybatis报错:Invalid bound statement (not found)

我是一个初学者,学习mybatis框架。我查询可以查得出结果,但是添加就不能出结果。

首先这是实体数据类

package test;

public class Book1 {
    private String name;
    private String author;

    public String getName() {
        return name;
    }

    public String getAuthor() {
        return author;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

    public Book1(String name, String author) {
        this.name = name;
        this.author = author;
    }

    @Override
    public String toString() {
        return "Book{" +
                "name='" + name + '\'' +
                ", author='" + author + '\'' +
                '}';
    }

    public Book1() {
    }
}

然后是mapper接口

public interface Bookmapper {
    public List<Book1> select(String s);
    public void add(Book1 book1);
}

两个xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="test.Bookmapper">
    <select id="select" resultType="test.Book1" parameterType="String">
        select * from book where author = #{author}
    </select>
    <insert id="add" parameterType="test.Book1" databaseId="mysql">
        insert into book (name,author) values(#{name}, #{author})
    </insert>
</mapper>
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">

<configuration>

    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/class?verifyServerCertificate=false&amp;useSSL=false"/>
                <property name="username" value="root"/>
                <property name="password" value="weiziyao1214"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="mapper.xml"/>
    </mappers>
</configuration>

这是测试类

public class Text {
    @Test
    public void test() throws IOException {
        Book1 b=new Book1("悉达多","黑塞");
        String resource = "mybatis.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory =
                new SqlSessionFactoryBuilder().build(inputStream);

        try (SqlSession session = sqlSessionFactory.openSession()) {
            Bookmapper mapper = session.getMapper(Bookmapper.class);
            List<Book1> book = mapper.select("川端康成");
            System.out.println(book);
            mapper.add(b);
            session.commit();
        }

    }
}

输出结果如下

[Book{name='雪国', author='川端康成'}, Book{name='雪国', author='川端康成'}]

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): test.Bookmapper.add

奇怪的是,我查询单条结果的时候返回为空,当我把返回值变成结果集的时候返回成功。但是添加操作就是不成。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • u010565545
    sh_c_2450957609 2021-01-22 08:17
    已采纳

    通过查看你的异常:BindingException: Invalid bound statement (not found): test.Bookmapper.add

    你的接口方法和xml文件中的add方法映射存在问题:

    <insert id="add" parameterType="test.Book1" databaseId="mysql">

    只需要把 databaseId="mysql" 删除就可以了,配置多数据库时用的,这还用不到.

    改成这样就可以了:

    <insert id="add" parameterType="test.Book1" >

    点赞 评论
  • qq_40693603
    sinJack 2021-01-22 11:05

    插入时,定义的databaseId=“mysql”,这个属性并没有加载到。导致的报错。

    点赞 评论
  • qq_40693603
    sinJack 2021-01-22 11:07

    你在mybayis中配置了mybatis数据库,如果配置的是多数据库,才需要用到这个属性来指定使用具体的数据库,否则不需要用该属性

    点赞 评论
  • bill20100829
    歇歇 2021-01-22 15:48

    各种可能原因有:

    **1.你的mapper写在了java目录里面。*例如下图:这样会出现一个问题,即使你在properties里面配置了 mybatis.mapper-locations= classpath:com/lihaoyu/demo/dao/*.xml,也没有用,因为编译的时候这个xml文件并没有被自动拉到target里面,毕竟编译的是.java文件而不是xml嘛,所以这时候应该在pom文件里面加上:
    项目目录结构

     </build>
            <resources>
                <resource>
                    <directory>src/main/java</directory><!--所在的目录-->
                    <includes><!--包括目录下的.properties,.xml文件都会扫描到-->
                        <include>**/*.properties</include>
                        <include>**/*.xml</include>
                    </includes>
                    <filtering>false</filtering>
                </resource>
            </resources>
        </build>
    

    如果你把xml放到了resources文件下,那么就只需要配置mybatis.mapper-locations=classpath:*/mapper/*.xml 就可以了,因为构建的时候会把resources里的东西自动拉到classpath下,注意.classpath意思就是编译后target文件夹下的classes目录.

    2.xml里面的namespace不对 或者id和mapper里面的方法名不一样,或者parameterType对应不上,都会出现这种问题。

    在这里插入图片描述

    点赞 评论

相关推荐