一、MyBatis详解
# 1.1、历史
最初是Apache的一个开源项目iBatis,2010年6月从Apache Software Foundation迁移到了Google Code,之后正式更名为MyBatis,并于2013年11月迁移到GitHub。
iBatis一词来源于“internet”和“abatis”的组合,是一个基于Java的持久层框架。iBatis提供的持久层框架包括SQL Maps(SQL映射,把Java中的实体类对象映射为数据库中的记录)和Data Access Objects(DAO,数据访问对象)
# 1.2、特性
- 支持定制化SQL(自己编写SQ语句)、存储过程以及高级映射(字段名不一致映射,多对一,一对多)
- 避免了几乎所有的JDBC代码(封装JDBC代码)和手动设置参数(将重要参数手动拼接到SQL)以及获取结果集(不需要手动获取结果集和解析结果集,配置好之后自动就转换为对象了)
- 使用简单的XML或注解用于配置和原始映射,将接口和Java中的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录
- Mybatis是一个半自动(Hibernate是全自动,不需要自己写SQL,Mybatis需要自己写SQL,JDBC数据转换过程也需要自己去写,是纯手动)的ORM(Object Relation Mapping,对象关系映射,将Java对象映射为数据库记录,将数据库记录查询为一个Java对象)框架
# 1.3、和其他持久层技术对比
- JDBC
- SQL 夹杂在Java代码中耦合度高,导致硬编码内伤
- 维护不易且实际开发需求中 SQL 有变化,频繁修改的情况多见
- 代码冗长,开发效率低
- Hibernate和JPA
- 操作简便,开发效率高(全自动)
- 程序中的长难复杂 SQL 需要绕过框架
- 内部自动生产的 SQL,不容易做特殊优化
- 基于全映射的全自动框架,大量字段的 POJO 进行部分映射时比较困难
- 反射操作太多,导致数据库性能下降
- MyBatis
- 轻量级,性能出色
- SQL 和 Java 编码分开,功能边界清晰。Java代码专注业务、SQL语句专注数据
- 开发效率稍逊于HIbernate,但是完全能够接受
编辑 (opens new window)
上次更新: 2024/05/30, 07:49:34