mybatis框架介绍
MyBatis,这一广受欢迎的开源项目,起源于Apache软件基金会旗下的iBatis框架。随着其不断的发展与演进,MyBatis在2010年经历了重要的转折点,由Apache软件基金会迁移至Google Code平台,并正式更名为MyBatis。而后,为了更广泛地拥抱开源社区,2013年11月,MyBatis再次迁移至GitHub——这一全球知名的开源及私有软件项目托管平台,进一步推动了其在软件开发领域的普及与应用。
支持。
MyBatis的优点
- 轻量级与易上手:MyBatis设计简洁,核心功能紧凑,无需复杂的第三方依赖。其安装配置过程简单,通常只需引入少量JAR文件并配置几个SQL映射文件即可迅速启动。这使得学习和使用MyBatis变得相对容易,降低了入门门槛。
- 高度灵活性:MyBatis不会对应用程序的架构或数据库设计施加限制。它允许开发者将SQL语句灵活地编写在XML映射文件中,这种管理方式便于SQL语句的集中审查、优化和版本控制,同时保持了代码与数据库之间的松耦合关系。
- 解耦与可维护性:通过提供清晰的DAO层接口,MyBatis有效地将业务逻辑与数据访问逻辑分离,增强了系统的模块化设计。这种分离不仅使系统结构更加清晰,还促进了代码的复用性、可测试性和可维护性。特别是SQL语句与Java代码的分离,极大地提升了代码的可读性和修改便利性。
MyBatis的不足
- SQL编写负担:随着应用程序复杂度的增加,尤其是当处理大量字段和多表关联查询时,编写和维护SQL语句的工作量会显著增加。这要求开发者具备良好的SQL编写能力和对数据库结构的深入理解。
- 数据库依赖性:由于MyBatis直接将SQL语句嵌入到代码中(尽管是通过XML或注解形式),这使得应用程序在一定程度上依赖于特定的数据库系统。当需要更换数据库时,可能需要修改大量的SQL语句,增加了迁移成本。
- 功能局限性:虽然MyBatis作为一款持久层框架已经相当成熟,但相对于一些更全面的ORM框架(如Hibernate),其功能可能略显简陋。在某些复杂场景下,MyBatis可能无法提供足够的抽象和自动化支持,需要开发者手动处理更多细节。
官方网站及框架包下载
官网地址:http://www.mybatis.org/mybatis-3/
源码和包下载地址:https://github.com/mybatis/mybatis-3/releases
配置文件
- 全局配置文件(核心配置文件):
mybatis-config.xml
,其主要作用是配置数据源(即数据库的连接信息),以及引入映射文件(Mapper XML文件)。这个文件是MyBatis框架启动和运行的基础配置。 - 映射文件:
XxMapper.xml
(其中Xx
代表具体的映射器名称),该文件用于配置SQL语句、定义SQL执行时所需的参数类型,以及指定SQL执行结果应如何封装成Java对象。映射文件是实现ORM(对象关系映射)的关键。
2、SqlSessionFactory
- 作用:
SqlSessionFactory
是MyBatis的核心接口之一,负责创建SqlSession
实例。通过调用SqlSessionFactoryBuilder
的build
方法,并传入配置文件(如mybatis-config.xml
)的输入流,可以构建出一个SqlSessionFactory
实例。
3、SqlSession
- 作用:
SqlSession
是MyBatis执行CRUD(创建、读取、更新、删除)操作的主要接口。它提供了大量的方法来直接执行映射的SQL语句,并返回映射结果。
4、Executor
- 执行器:在MyBatis内部,
SqlSession
通过调用Executor
来完成具体的CRUD操作。Executor
是MyBatis操作数据库的核心组件,它封装了JDBC的所有操作细节,使得开发者可以专注于SQL语句本身,而无需关心底层的数据库连接、事务处理等复杂问题。
5、Mapped Statement
- 在映射文件
XxMapper.xml
中配置,每个Mapped Statement
都包含了三个部分的重要信息:具体的SQL语句、SQL执行所需的参数类型、以及SQL执行结果的封装类型。这些配置信息告诉MyBatis如何执行SQL语句,并如何将执行结果映射回Java对象。 - 参数类型和结果集封装类型主要包括三种形式:
HashMap
:适用于灵活的键值对映射,但通常不推荐用于复杂的对象映射。- 基本数据类型及其包装类:适用于单个值的传递和返回。
- POJO(Plain Old Java Object,普通老式Java对象):适用于复杂的对象映射,能够自动将SQL查询结果映射到Java对象的属性中。