1:Mybatis执行流程
回答:
- 读取Mybatis配置文件:mybatis-config.xml加载运行环境和映射文件
- 构造会话工厂SqlSessionFactory
- 会话工厂创建SqlSession对象(包含了执行SQL语句的所有方法)
- 操作数据库的接口,Executor执行器,同时负责查询缓存的维护
- Executor接口的执行方法中有一个MappedStatement类型的参数,封装了映射信息
<select id="selectUserList" resultType="com.mybatis.User"> select * from t_user
</select>
- 输入参数映射
- 输出结果映射
用代码进行说明
public class MybatisTest {public static void main(String[]args) throws Exception {// 1.加载配置文件InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");//2. 创建SqlSessionFactory对象实际创建的是DefaultSqlSessionFactory对象SqlSessionFactory builder = new SqlSessionFactoryBuilder().build(inputStream);//3. 创建SqlSession对象实际创建的是DefaultSqlSession对象SqlSession sqlSession = builder.openSession();//4. 创建代理对象UserMapper mapper = sqlSession.getMapper(UserMapper.class);//5. 执行查询语句List<User> users = mapper.selectUserList();//6. 释放资源sqlSession.close();inputStream.close();}
}
2:Mybatis是否支持延迟加载
回答:
● 延迟加载的意思是:在需要用到数据时才进行加载,不需要用到数据时就不加载数据
● Mybatis支持一对一关联对象和一对多关联集合对象的延迟加载
● 在Mybatis配置文件中,可以配置是否启用延迟加载lazyLoadingEnabled=true|false,默认是关闭的
注意:在xxMapper.xml文件中配置的不是全局,全局需要在mybatis-config.xml文件中进行配置
3:延迟加载的底层原理知道吗
回答:
● 使用CGLIB创建目标对象的代理对象
● 当调用目标方法时,进入拦截器invoke方法,发现目标方法是null值,执行sql查询
● 获取数据以后,调用set方法设置属性值,再继续查询目标方法,就有值了
4:Mybatis的一级、二级缓存用过吗
回答:
● 一级缓存:基于PerpetualCache的HashMap本地缓存,其存储作用域为Session,当Session进行flush或close之后,该Session中的所有Cache就将清空,默认打开一级缓存
● 二级缓存是基于namespace和mapper的作用域起作用的,不是依赖于SQL session,默认是采用PerpetualCache,HashMap存储。需要单独开启,一个是核心配置,一个是mapper映射文件‘
5:Mybatis的二级缓存什么时候会清理缓存中的数据
回答:
当某一个作用域(一级缓存Session/二级缓存Namespaces)的进行了新增、修改、删除操作后,默认该作用域下所有select中的缓存将被clear。