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的生命周期。