为什么阿里巴巴的持久层抛弃hibernate,采用MyBatis框架?
原因大概有以下4点:
尤其是需要处理大量数据或者大并发情况的网站服务,这也阿里选择MyBatis的原因。
MyBatis整体架构
不多讲,先看目录图
MyBatis源码笔记文档
第1部分 MyBatis 入门
MyBatis 是一个容易上手的持久层框架,使用者通过简单的学习即可掌握其常用特性的用法,这也是MyBatis 被广泛使用的原因之一。在深入分析MyBatis 源码前,先介绍一下MyBatis 的一些基础知识。
第2部分 配置文件解析过程
按照 MyBatis 启动流程,这部分将会对 MyBatis 解析配置文件的过程进行分析。我们在使用 MyBatis 框架时,通常会进行一定的设置,使其能更好的满足我们的需求。对于一个框架来说,提供较为丰富的配置文件,也是其灵活性的体现。将会介绍 MyBatis 配置文件中的大部分节点解析过程,包含但不限于 properties、settings、typeAliase、typeHandlers 等
第3部分 映射文件解析过程
这部分是分析映射文件解析的过程。与配置文件不同,映射文件用于配置 SQL语句,字段映射关系等。映射文件中包含、、、<select|insert|update|delete>等二级节点,这些节点将在接下来内容中进行分析。
第4篇 SQL执行流程
将对 MyBatis 执行 SQL 的过程进行较为详尽的分析。该过程比较复杂,涉及的技术点很多。
第5部分 内置数据源
MyBatis 支持三种数据源配置, 分别为 UNPOOLED 、POOLED 和 JNDI 。并提供了两种数据源实现,分别是UnpooledDataSource 和 PooledDataSource 。在这三种数据源配置中, UNPOOLED 和POOLED 是我们最常用的两种配置,这两种数据源也是本章要重点分析的对象。
第6篇 缓存机制
在 Web 应用中,缓存是必不可少的组件。通常都会用 Redis 或 memcached 等缓存中间件,拦截大量奔向数据库的请求,以减轻数据库压力。作为一个重要的组件,MyBatis 自然也在内部提供了相应的支持。通过在框架层面增加缓存功能,可减轻数据库的压力,同时又可以提升查询速度,可谓一举两得。MyBatis 缓存结构由一级缓存和二级缓存构成,这两级缓存均是使用 Cache 接口的实现类。因此本章将首先会向大家介绍 Cache 几种实现类的源码,然后再分析一级和二级缓存的实现。
第7篇 插件机制
开发 MyBatis 插件需要对 MyBatis 比较深了解才行,一般来说最好能够掌握 MyBatis 的源码,门槛相对较高。
总结
阿里伤透我心,疯狂复习刷题,终于喜提offer 哈哈~好啦,不闲扯了,文章开头说要免费给大家分享我的复习资料,下面就给大家展示一下——点击这里免费获取我的复习刷题宝典
1、JAVA面试核心知识整理(PDF):包含JVM,JAVA集合,JAVA多线程并发,JAVA基础,Spring原理,微服务,Netty与RPC,网络,日志,Zookeeper,Kafka,RabbitMQ,Hbase,MongoDB,Cassandra,设计模式,负载均衡,数据库,一致性哈希,JAVA算法,数据结构,加密算法,分布式缓存,Hadoop,Spark,Storm,YARN,机器学习,云计算共30个章节。
2、Redis学习笔记及学习思维脑图
3、数据面试必备20题+数据库性能优化的21个最佳实践
681)]
3、数据面试必备20题+数据库性能优化的21个最佳实践
[外链图片转存中…(img-y9lbjl20-1625658117682)]