MyBatis简介

1.Mybatis的优点

1.不屏蔽SQl,可以精确定位Sql语句,对其进行优化和改造,有利于优化互联网系统性能。

2.提供动态Sql,开发人员可以根据业务需要动态拼接Sql语句,有比较好的Java编码的可读性和可维护性。

3.提供使用了Mapper接口编程,只需要一个接口和XML文件就能创建映射器,简化了持久层框架搭建难度。

2.MyBatis的核心组件

 Mybatis的核心组件分为如下4个部分:

1.SqlSessionFactoryBuilder(构造器):它是根据配置或者代码生成SqlSessionFactory工厂,采用的是分布构建的Builder模式。

2.SqlSessionFactory(工厂接口),依靠它 来生成SqlSession,使用的工厂模式。

3.SqlSession(会话):一个既可以发送Sql又可以获取Mapper的接口。(现实开发技术中,一般不出现在业务代码逻辑中,主要使用的是Mybatis提供的Sql Mapper接口编程技术)。

4.Sql Mapper(映射器):它由一个Java接口和Xml文件构成,需要给出对应的Sql和映射规则,它负责发送Sql的执行,并返回结果。

各组建的关系图如下:

3.生命周期

SqlSessionFactoryBuilder:SqlSessionFactoryBuilder的作用在于创建SqlSessionFactory,创建成功后SqlSessionFactoryBuilder就失去了作用,所以它只能存在与创建SqlSessionFactory的方法中,而不要让其长期存在。

SqlSessionFactory:SqlSessionFactory可以认为是一个数据库连接池,它的作用是创建SqlSession接口对象。因为MyBatis的本质就是Java对数据的操作,所以SqlSessionFactory的生命周期存在于整个Mybatis应用之中。所以SqlSessionFactory的生命周期就等同于MyBatis的生命周期。

SqlSession:相当于一个数据库连接对象(Connection对象),你可以在一个事务里面执行多条Sql,然后通过它的commit、rollback等方法提交或会滚事务,所以它的生命周期存在于一个业务请求中,处理完整个请求后,应该关闭这条连接,避免数据库资源被耗光。

Mapper:Mapper是由SqlSession所创建,所以Mapper的生命周期至多与SqlSession的生命周期保持一致。由于SqlSession的关闭,它的连接资源也会消失,所以Mapper的生命周期小于等于SqlSession的生命周期。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值