Mybatis注解sql时出现的一个错误及解决

这篇文章主要介绍了Mybatis注解sql时出现的一个错误及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

一.  错误

在做Mybatis用注解方式来注入sql的练习时,报了这样子的错误。

遇到错误很正常,然后我又从学了一遍今天刚刚学的内容,温故而知新嘛。

错误问题如下:

二.  文件结构 

BookMapper.java

public interface BookMapper { @SelectProvider(type = BookMapperSQL.class,method = "bookSelectById") Book bookSelectById(int id); }

BookMapperSQL .java

public class BookMapperSQL { public String bookSelectById(final int id){ return new SQL(). SELECT("*") .FROM("t_user") .WHERE("id=#{id}").toString(); } }

然后我把BookMapper.xml的内容都删完了,没有把文件删掉,目录如下:

Mybatis的配置文件

这个映射用包用类其实都没有影响,因为我们做的是注解配置

        

三.  分析

从上面的文件看,我的问题很大部分原因应该在这个mapper的包里面。然后就是看参数有没有个数对齐,但是也不会导致这样的错误说是错误解析SQL Mapper配置,所以这个问题我一开始纠结于那个BookMapperSQL .java的内容是不是写错了,研究了一个多小时,直接重学了一遍,哭了。

后来我在想,会不会是因为我拿的是我之前做的作业修改的而出现的问题。然后我就看了我之前的文件目录

我突然想起之前做这个动态代理方式实现的方式时,pom.xml文件做了配置,指定了mapper包中。

难道就是因为指定了位置,文件加载所以出问题了吗?所以我就把这段代码注释掉

然后它就运行成功了。 

当热,我们在使用注解方式注入sql时,mapper包中没必要再加这个文件了,只能说是自己愚钝了,上网查都没有人像我一样这么乌龙了。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持0133技术站。

以上就是Mybatis注解sql时出现的一个错误及解决的详细内容,更多请关注0133技术站其它相关文章!

赞(0) 打赏
未经允许不得转载:0133技术站首页 » Java