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。