MyBatis的基本概念和核心组件

MyBatis的基本概念

MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录

MyBatis的特点

  • 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件。易于学习,易于使用。通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
  • 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
  • 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
  • 提供映射标签,支持对象与数据库的ORM字段关系映射。
  • 提供对象关系映射标签,支持对象关系组建维护。
  • 提供xml标签,支持编写动态sql

MyBatis架构

我们把MyBatis架构分为三层

  1. API接口层的主要作用
    • 定义接口方法:API接口层主要用于定义与数据库交互的方法。通常,每个接口方法对应一条SQL语句或一组相关的SQL语句,用于执行查询、插入、更新或删除等数据库操作
    • 参数传递:API接口层可以定义方法的输入参数,用于传递查询条件、更新数据等操作所需的参数。MyBatis提供了各种方式来传递参数,包括基本类型、对象、Map等。
    • 结果映射:API接口层可以定义方法的返回类型,用于接收数据库操作的结果。MyBatis支持将查询结果映射为Java对象或集合,并提供了丰富的结果映射规则和配置方式。
    • SQL语句映射:API接口层可以通过注解或XML配置的方式,将SQL语句与接口方法进行映射。这样,在调用接口方法时,MyBatis会自动执行对应的SQL语句,并将结果返回给调用方。
    • 事务支持:API接口层可以通过注解或XML配置的方式,添加事务的支持。这样,在接口方法执行期间,可以保证数据库操作的原子性,保证数据的一致性和完整性。
  2. 数据处理层的主要作用
    • 定义映射关系:数据处理层使用映射文件或注解来定义数据库表与Java实体对象的映射关系。这些映射关系包括表名、字段名、主键、关联关系等。通过定义映射关系,MyBatis可以将查询结果自动映射为Java对象。
    • 编写SQL语句:数据处理层使用SQL语句来执行数据库的增删改查操作。SQL语句可以使用MyBatis提供的映射文件或注解来定义,也可以使用动态SQL来实现灵活的条件查询。SQL语句可以包括普通的SQL语句、参数占位符、动态条件等。
    • 执行数据库操作:数据处理层使用Mapper接口来执行数据库操作。Mapper接口定义了与数据库操作相关的方法,例如插入数据、更新数据、删除数据、查询数据等。通过调用Mapper接口的方法,可以执行对应的SQL语句并返回结果
    • 事务管理:数据处理层可以通过注解或配置文件来管理事务。在需要保证多个数据库操作的原子性时,可以使用事务管理来确保数据的一致性和完整性。MyBatis提供了多种方式来配置和管理事务,例如使用注解、使用AOP、使用XML配置等。
  3. 基础支撑层的主要作用
    • 数据源管理:基础支撑层负责管理应用程序连接数据库的数据源。它可以配置和管理连接池,提供数据库连接的分配和释放,以及数据库事务的管理等。
    • SQL语句执行:基础支撑层提供了执行SQL语句的能力。它负责将SQL语句和参数传递给数据库,并获取执行结果。它还负责处理SQL语句的预编译、占位符替换、结果集的映射等操作。
    • 对象-关系映射:基础支撑层负责将数据库中的记录映射为Java对象。它可以根据配置或注解,自动将查询结果集映射为Java对象,并提供对象与数据库记录之间的转换功能。
    • 缓存管理:基础支撑层提供了缓存机制,用于提高数据库访问性能。它可以缓存查询结果,避免重复访问数据库,提高响应速度。MyBatis提供了不同级别的缓存配置,包括一级缓存和二级缓存。
    • 异常处理:基础支撑层处理数据库操作过程中可能出现的各种异常,如数据库连接异常、SQL语句执行异常、事务回滚等。它负责将异常转换为可读的错误信息,并提供异常处理机制。

MyBatis核心组件

  1. SqlSessionFactory:SqlSessionFactory是MyBatis的核心接口之一,它负责创建SqlSession对象。SqlSession是与数据库交互的主要入口,通过SqlSessionFactory可以获取SqlSession实例,然后进行数据库操作。
  2. SqlSession:SqlSession是MyBatis与数据库交互的关键组件,它提供了执行SQL语句、获取映射器(Mapper)、管理事务等功能。通过SqlSession,可以执行数据库的增删改查操作,并获取操作结果。
  3. SqlSession:SqlSession是MyBatis与数据库交互的关键组件,它提供了执行SQL语句、获取映射器(Mapper)、管理事务等功能。通过SqlSession,可以执行数据库的增删改查操作,并获取操作结果。
  4. 映射器(Mapper):映射器是MyBatis实现动态代理的核心组件。MyBatis通过JDK动态代理或CGLIB动态代理,根据定义的Mapper接口,动态生成代理类,实现接口方法的具体逻辑。通过映射器,可以将Java对象与数据库记录进行映射,实现对象关系映射。
  5. Configuration配置对象:Configuration对象是MyBatis的配置文件解析和存储的核心组件。它负责解析MyBatis的配置文件,包括数据库连接信息、映射文件路径、插件、类型处理器等配置信息。MyBatis根据Configuration对象的配置,完成MyBatis的初始化和功能扩展。
  6. Executor执行器:Executor执行器是MyBatis执行SQL语句的核心组件。它负责根据SQL语句、参数和映射规则,将SQL语句发送到数据库,并获取结果。Executor可以分为SimpleExecutor、ReuseExecutor和BatchExecutor等类型,用于不同的场景和需求。

猜你喜欢

转载自blog.csdn.net/m0_65491952/article/details/132298068