一、MyBatis简介
1、MyBatis历史
MyBatis最初是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Software Foundation迁 移到了Google Code。随着开发团队转投Google Code旗下, iBatis3.x正式更名为MyBatis。代码于 2013年11月迁移到Github。
iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。 iBatis提供的持久层框架 包括SQL Maps和Data Access Objects(DAO)。
2、MyBatis特性
-
MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架
-
MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集
-
MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录
-
MyBatis 是一个 半自动的ORM(Object Relation Mapping)框架
3、MyBatis下载
MyBatis下载地址:https://github.com/mybatis/mybatis-3
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DkEFpYzd-1686188962808)(https://xiaoxue-blog.oss-cn-shenzhen.aliyuncs.com/blog/202207071713678.png?x-oss-process=style/style_one)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lHQeEHP1-1686188962808)(https://xiaoxue-blog.oss-cn-shenzhen.aliyuncs.com/blog/202207071713947.png?x-oss-process=style/style_one)]
4、和其它持久化层技术对比
-
JDBC
- SQL 夹杂在Java代码中耦合度高,导致硬编码内伤
- 维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见
- 代码冗长,开发效率低
-
Hibernate 和 JPA
- 操作简便,开发效率高
- 程序中的长难复杂 SQL 需要绕过框架
- 内部自动生产的 SQL,不容易做特殊优化 基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难。
- 反射操作太多,导致数据库性能下降
-
MyBatis
- 轻量级,性能出色
- SQL 和 Java 编码分开,功能边界清晰。Java代码专注业务、SQL语句专注数据
- 开发效率稍逊于HIbernate,但是完全能够接受