解决org.apache.ibatis.binding.BindingException Invalid bound statement (not found) com.fs.mapper.UserM

首先我们来看看我的修改前的Mapper.xml文件

<mapper namespace="com.fs.mapper.UserMapper">
    <select id="selectAllUser" resultType="com.fs.pojo.User">
        select * from tb_user;
  </select>
</mapper>

其次是我的Mapper接口的代码

public interface UserMapper  {
​
    List<User> selectAll();
}

最后再来看看测试类的代码

    @Test
    public void test() throws IOException {
​
​
        //1.加载mybatis的核心配置文件,获取SQLSessionFactory
        String resource = "mybatisConfig.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
​
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
​
        //2.获取SqlsSession对象,用它来执行sql
        SqlSession sqlSession = sqlSessionFactory.openSession();
​
​
        //3.1 mapper代理开发,获取UserMapper接口的代理对象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        List<User> users = mapper.selectAll();
​
​
        System.out.println(users);
​
        //4.释放资源
        sqlSession.close();
    }

因为是初学mybatis,对其并没有太多的研究,最后发现是我的Mapper.xml文件中的Id与Mapper接口中的方法名没有对应,导致在实现接口时,并没有找到对应的sql,也就报错了,解决方案就是把Mapper.xml文件中的ID与接口中的方法名一致即可

修改后:

Mapper.xml文件

<mapper namespace="com.fs.mapper.UserMapper">
    <select id="selectAllUser" resultType="com.fs.pojo.User">
        select * from tb_user;
  </select>
</mapper>

Mapper接口:

public interface UserMapper  {
​
    List<User> selectAllUser();
}

测试类:

  @Test
    public void test() throws IOException {
​
​
        //1.加载mybatis的核心配置文件,获取SQLSessionFactory
        String resource = "mybatisConfig.xml";
        InputStream inputStream = Resources.getResourceAsStream(resource);
​
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
​
        //2.获取SqlsSession对象,用它来执行sql
        SqlSession sqlSession = sqlSessionFactory.openSession();
​
​
        //3.1 mapper代理开发,获取UserMapper接口的代理对象
        UserMapper mapper = sqlSession.getMapper(UserMapper.class);
        List<User> users = mapper.selectAll();
​
​
        System.out.println(users);
​
        //4.释放资源
        sqlSession.close();
    }

运行即可

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值