Springboot整合mybatis,这在很多项目中都会用到。本人小白,想用它搞个数据库玩玩。在此记录下,以供参考回顾。
1.什么是mybatis?
一个整合JDBC快速开发的持久层框架;深层面不解释,先用起来再说。
2.怎么整合?
网上对此,一堆堆的文章,然后,复杂的配置+长篇大论,真让人昏昏。这里推荐一篇极简的上手文章:https://www.jianshu.com/p/c2444ddd2de9。
3.我的调试过程及教训:
开始我认为会很简单,(其实也是很简单)但我从项目的代码摘录和配置完毕后,首先遇到第一个坑是:我新写的代码编译不过。。。比如其中import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;语句中jdbc库总是不认,用IDEA 自动加载,pom中添加了,但却告诉我can't resolve symbol xxxxxx. 代码保持标红状态,编译器还是不认。。。一查工程列出的外部依赖Lib库,果然没有对应的springframework.jdbc jar包,难怪会报错了。但为什么IDEA没有自动加入这个依赖库,jar包呢?没道理啊,IDEA这么强大,还不能自动加入这个jar包?于是,在这个问题上,纠结了半天。。。。最后我的DOUBLE哥给我支招,终于解决。我终于能12点前睡觉了。。。。其实原因就是我自己摘录项目pom文件时,自己又乱加了很多不用的依赖项,而这些pom文件的依赖项之间又有冲突,导致IDE就不知道用哪个了。
对策:自己不用的依赖库,或不清楚的库,不要随便写到pom文件。一旦遇到IDE 无法解析的情况,可以从零一个个加,依次找到问题所在。(这里非常感谢DOUBLE哥,迅速让我走到正确的道路上)
终于全部编译成功,满心欢喜的run。然后Demo程序却报错,说创建不了bean XXXDao。。。。。一通检查,发现自己的代码没错啊?怎么回事,于是,第一件事:撤掉自己新写的代码。找个项目中能用的Dao文件替换,看看能否run。然后,发现,还是不行。。。。到此,我也明白不是自己的代码问题,还是JAVA的配置问题。那么是哪个呢?真心说句,java的配置很重要,写C++没什么配置问题,而JAVA很多的框架,注解和依赖,效率比C++高很多,但前提是要正确配置才能work。 于是,自己和项目中的每一个配置文件进行对比,修改。所有的xml、yml、properties文件除了路径不一样,我都改成一样的了。再跑,然并卵!此时,我一方面寻求朋友同事的帮助,一方面想我的根本目的是什么?
其实我的根本目标就是整合mybatis,用db存数据。那么正常的流程是怎么做的呢?对此,我上网找相关的文章。看看有没简单的上手例子。果然,我找到了上面那篇文章。我根据上面的文章,搭建了一个很简单的用mybatis的demo。发现能用了。。。而能用的关键就只有三处:
1. Dao类上面必须要有注解@Mapper
2.POM文件中必须添加对应的mybatis依赖项和MySql DB依赖:
这里,注意,只要这两项,而且必须是Springboot的mybatis库。。。这点很重要。
3.Dao类接口方法写对应的SQL语句。如下:
接口操作可用注解也可用配置文件来搞定。
然后就可以操作db了。
据此,我发现第1,第3步都没问题,但唯独第2步,我用的是IDE的自动加载依赖项和jar包的方式。问题难道出在这??然后,我一对比POM文件,发现mybatis的设置果然不一样。我的Demo程序用的不是springboot的mybatis库。于是,我什么也没改,我把数据库的那几个自动加载的依赖项改成上面的两项。 run, OK了。
对策:配置,配置,配置,重要的事情说三遍。 如果出错,代码觉得没问题时,一定要想我要解决什么问题,通常流程需要什么配置。先搞一个简单的能run的demo,再回去解决自己的问题。(这里非常感谢同事朋友帮助,他后来在他电脑上的实验佐证了我的想法)