(具体关键字不懂得去度娘,给我留言也可以)
Mybatis是一个优秀企业级的并且适合数据吞吐量大的,有着灵活轻巧的结构,简单的编写过程,低成本学习的持久层框架。
好处那么多,就先说说搭建的过程。
简要搭建过程(不分先后):
1、 数据源交给Applicationcontext配置文件(spring核心配置文件)去获取,数据库参数信息从properties文件中获得,使数据库迁移变得轻松,解耦嘛。
2、 Spring整合Mybatis,将Mybatis交给Spring来管理,控制反转。将数据源交给Mybatis,指定MyBatis的配置文件路径,MyBatis使用的别名包路径(Mybatis会将数据库中的数据映射到对象中,对象需要注解注释对应哪张表,以及主键,其他可选),会根据指定的映射文件地址去加载映射文件,并且指定扫描接口的包路径。
ApplicationContext-Mybatis.xml
3、 Mybatis-config
驼峰映射规则,就是数据库列名映射成对应对象中的属性名的书写规则,这也是规范,默认开头小写中间每一个单词开头大写,有了规范,数据库才能和对象中的具体属性映射无差错。默认Mybatis一级缓存是开启的sqlsession级别,二级缓存是mapper级别的,我管理的项目用redis集群替代了,原因很简单,redis更专业也更适合大数据。这里还不得不提到主键自增的问题,我用的是mysql,最后指定一个通用mapper(已经实现很多接口的mapper,一些常用的功能直接用就好了)。
4、 可以编写mapper(接口用于和service交互)和Xml(实现和数据库的交互)了,编写好的mapper接口传入的对象,在xml中会接住,并将对象中的属性一一映射到SQL语句中,语句发送给DBMS执行。编写的Xml中会包含所对应mapper的全路径,这样当service调用mapper的时候,Mybatis就会将我们指向他已经扫描完并且有对应mapper全路径的xml去执行SQL语句。
结束语:此文件通俗易懂,内部过程请翻看源码。