MyBatis知识点总结

MyBatis知识点总结

一. MyBatis核心组件

1.SqlSessionFactoryBuilder(构造器):根据配置和代码生成SqlSessionFactory,采用分布构建Builder模式。
2.SqlSessionFactory(工厂接口):生成SqlSesssion,使用工厂模式。
3.SqlSession(会话):既可以发送sql执行返回结果,也可以获取Mapper的接口。
4.SqlMapper(映射器):由Java接口和XML文件构成,需要给出对应的映射规则,负责发送SQL执行(底层还是用SqlSession)。

生命周期

1.SqlSessionFactoryBuilder(构造器): 构建完SqlSessionFactory就自动销毁。
2.SqlSessionFactory(工厂接口):在一个MyBatis应用中存在一个实例(单例),相当于一个大的数据库连接池。
3.SqlSession(会话):一个业务请求中就有一个,完成请求后就关闭。
4.Mapper(映射器):由SqlSession构建,生命周期小于等于SqlSession。

二.MyBatis配置

概述简图

在这里插入图片描述

1.properties属性

1.1直接配置子元素指定name和value,可以在后续的MyBatis配置文件中使用。
1.2properties文件,配置在classPath下,使用resource属性引进MyBatis配置文件中。

2.setting配置

setting配置是最复杂的一个配置,可以配置MyBatis的底层运行模式,包括自动映射,驼峰规则,级联规则,启动缓存,执行器类型等等。

3.typeAliases别名(需要注册)

MyBatis在这里给类定义别名,通过TypeAliasRegister管理,不区分大小写!
别名包括自定义别名和系统定义别名。

4.typeHandler类型转换器(需要注册)

typeHandler负责转换JDBC查询数据库的结果(数据库类型)和Java类型,实现接口TypeHandler。
在MyBatis中,数据类型有俩类,一个JavaType,一个JdbcType,一条Sql语句中,例如 在where条件的参数里,我们写入的是JavaType,需要通过typeHandler转化为Jdbctype,同理的,sql执行完后返回的语句里,所有的类型都是JdbcType,我们也要通过typeHandler来转化为JavaType。

5.objectFactory构建返回结果集对象

主要是构建返回结果集对象,实现接口ObjectFactory,在数据库查完数据后发挥作用,构建list,构建返回的具体对象,在对对象赋值时调用typeHandler进行类型转化。

6.plugins插件,很复杂,后面说。
7.environment运行环境

运行环境是配置数据源和事务管理器的,数据源可能含有POOLED UNPOOLED JNDI等等的类型,事务管理器包括jdbc,managed(交给容器管理),一般现在这俩个都是通过spring进行管理的。

8.dabaseIdProvider数据库厂商标识

这个一般用来区分不同的数据库,例如mysql,orcle等等,配置type = DB_VENDOR,
属性prop后,在Mapper文件中的sql语句里加入databaseId指定使用哪个厂商的数据库,他的优先级高于没有配置这个属性的sql。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值