invalid bound statement (not found)报错

在使用Mybatis时,有两种加载方式

package com.mybatis.ui;

import java.util.List;

import org.apache.ibatis.session.SqlSession;

import com.mybatis.entity.User;
import com.mybatis.mapper.UserMapper;
import com.mybatis.util.MyBatisUtil;

public class Test {

	public static void main(String[] args) {
		// 创建SQLSession对象
		SqlSession session = MyBatisUtil.openSqlSession();
		//第一种方式,调用的是SqlSession中的select、insert、update、delete等方法
		//参数:映射器接口的权限定名+方法名(映射文件中namespace的值+某一条SQL语句映射的id属性值)
		List<User> users = session.selectList("com.mybatis.mapper.UserMapper.findAllUser");
		System.out.println(users);
		
		//第二种方式(推荐的方式)
		//参数是映射器接口的类型,返回值是该接口的实现类的对象
//		UserMapper userMapper = session.getMapper(UserMapper.class);
//		List<User> users = userMapper.findAllUser();
//		System.out.println(users);
		
		session.close();
	}

}

但是在使用后,发现第一种可以加载成功,但是第二种就会爆出如下异常
在这里插入图片描述
你不妨去检查一下你的映射器接口配置文件
一定要保证你的SQL语句的id值要和接口定义的方法名一致
这样才可以正确的使用第二种方式
因为第一种方式是你自己拼接的参数,不会报错
而第二种方式,就会依据你接口的方法来实例化,这就要保证id和方法名必须一致

Alt

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值