具体分析Mybatis是如何操作数据库的!
、
1、定义我们的核心配置文件的路径,这个路径是从target/classes下开始找的!
String config = "mybatis-config.xml" ;
2、读取这个config表示的文件
InputStream inputStream= Resources.getResourceAsStream(config);
3、创建SqlSessionFactoryBuilder对象
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
4、创建SqlSessionFactory对象
SqlSessionFactory sessionFactory = builder.build(inputStream);
5、获取SqlSession对象,从SqlSessionFactory中获取
SqlSession sqlSession = sessionFactory.openSession();
6、【重点】执行我们的执行的的sql语句标识。sql文件中的namespace + sql标签的Id值
String sqlId = "com.sqx.dao.UserMapper.getUserById";
7、执行sql语句,通过sqlId找到语句,并执行!
List<Object> objects = sqlSession.selectList(sqlId);
8、关闭SqlSession
sqlSession.close();
总结
Myabtis启动的时候会加载mybatis-config.xml这个核心配置文件,得到要操作的数据库以及我们Mapper文件的的信息,然后将其以数据流的形式保存起来传给SqlSessionFactoryBuilder,创造出对应该数据库的SqlSessionFactory工厂,工厂生产SqlSession,这个SqlSession中包含了对该库的增删改查方法,我们需要通过namespace + sqlId
来确定我们执行的是哪个sql,这一步操作可以通过SqlSeesion.getMapper()拿到接口,通过调用接口的方法(方法绑定了我们的sql,包含namespace + sqlId
),执行对应的SQL语句!
Mybatis缓存无论是一级缓存还是二级缓存都是本地缓存,都会占用JVM的内存,一旦Java停止缓存失效!
概述
如下是对一级缓存进行测试:
查看我们的测试结果
采用不同的SqlSession测试数据,进行如下修改!
我们再次查看测试结果
得出结论我们的一级缓存只是在同一个SqlSession当中有效!
概述
二级缓存又称"全局缓存",是基于namespace级别的缓存,一个namespace对应一个二级缓存!
工作机制:
使用步骤 :
只需在需要使用缓存的namespace 中加入< cache/>
即可
<!--在当前Mapper.xml中使用二级缓存,并配置相关参数-->
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
eviction :缓存的回收策略
LRU(最长时间未使用)、LFU(访问次数最少)、FIFO(默认)、SOFT(软引用)、WEAK(弱引用)
flushInterval : 缓存刷新间隔
缓存多久清空一次,默认是不会清空的,设置一个毫秒值
readOnly :是否只读
size :缓存存放多少元素
我们还可以通过配置实现自定义缓存
<!-- 开启mybatis的二级缓存,其本质还是我们mybatis帮我们实现了自身提供的缓存接口Cache,
也就是cache标签的type属性默认指定了缓存策略 -->
<cache type=""/>
<!--本质上就是这种写法,我们可通该修改type来选择自定缓存策略-->
<cache type="rg.apache.ibatis.cache.impl.PerpetualCache"/>
如图所示
缓存执行流程
什么是ORM
ORM(Object Relational Mapping),对象关系映射,是一种为了解决关系型数据库数据与简单 Java 对象(POJO)建里映射关系的技术。
为什么说 Mybatis 是半自动ORM映射工具?它与全自动的区别在哪里?
优点
基于SQL语句编写、相当灵活,SQL写在XML文件当中,解除了sql与程序代码的耦合,便于统一管理
消除了JDBC的冗余代码、能够与Spring很好的集成
缺点
SQL语句的编写工作量大,尤其是字段多,关联表多的情况下,对开发人员的SQL语句功底有一定的要求
SQL语句依赖数据库,导致数据库移植性差,不能随意更换数据库
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/m0_46571920/article/details/122515795
内容来源于网络,如有侵权,请联系作者删除!