mybaties错误解决Invalid bound statement (not found): com.yealink.example.dao.UserMapper.getUserByUserInf

一.错误:Invalid bound statement (not found): com.yealink.example.dao.UserMapper.getUserByUserInfo
 
二.解决过程
 
项目用spring+springMVC+mybatis;
我们发现他读不到userMapper.xml文件,后面查询在编译好的文件中,UserMapper.xml文件并没有引入进来,这就是导致出现这个问题的原因;
 
找到原因后我们在:选中项目 右击选中build path->configure build path->选中source,查看源文件下的Included:**/*.java ,表明编译后只把.java文件编译成.class后引入,其他的.xml文件不会引入,所以就会出现这个错误;
 
三.解决办法:将Included:**/*.java Remove掉
 
重新编译后发现.xml文件已经存在了,问题解决;
 
四.备注
但是如果你建立的是maven工程,每次用maven命令重新编译eclipse工程时,上述问题又会出现,因为Included:**/*.java为默认的,所以解决办法是在.pom文件中加入这一段配置
     <resources>
        	<resource>
        		<directory>src/main/java</directory>
        	</resource>
        	<resource>
        		<directory>src/main/resources</directory>
        	</resource>
        </resources>
意思是每次用maven编译时它会将src/main/java和src/main/resources下的所有文件都进行引入,所以问题完美解决;
这个错误信息通常在使用MyBatis(一个Java持久层框架)时出现,它表示试图执行一个无效的或未找到的查询绑定语句。"Invalid bound statement (not found): com.itFml.dao.UserMapper.loginUser" 这句话具体意味着在UserMapper接口中的`loginUser`方法没有被正确地映射到数据库的SQL语句。 UserMapper是一个Mapper接口,`loginUser`方法应该是定义了一个用于登录用户的查询。可能是以下几个原因导致这个错误: 1. **Mapper XML未配置**:确认`loginUser`方法是否在一个名为`UserMapper.xml`或者相应的XML映射文件中进行了正确的配置,并且该文件是否加载到MyBatis的环境中。 2. **方法名拼写错误**:检查`loginUser`方法名是否在Mapper接口和XML映射文件中一致,大小写敏感的。 3. **方法签名不匹配**:如果Mapper接口中的方法参数类型、数量或顺序与实际的数据库查询不符,也会导致这个错误。 4. **Mapper接口未正确导入**:确保`com.itFml.dao.UserMapper`已被正确导入,并且实现了Mapper接口。 5. **SqlSession未初始化**:在使用Mapper时,确保已经创建并初始化了SqlSession。 为了解决这个问题,你可以尝试检查上述的每一个环节,修复配置错误或者提供更多的上下文以便更精确地定位问题。如果你能提供具体的代码片段,可能会更容易找到解决方案。下面是相关问题: 1. 你在使用MyBatis时是如何配置Mapper接口和XML文件的? 2. `loginUser`方法在UserMapper接口中是什么样的声明(参数和返回类型)? 3. 有没有其他的错误堆栈信息可以帮助诊断?
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值