什么是Mybatis的一二级缓存?

一级缓存:

也称为 SqlSession 缓存,它存在于 SqlSession 中,只对一个会话内的数据进行缓存。如果在一个会话内多次执行同一条 SQL 查询语句,那么 MyBatis 只会在第一次查询数据库时实际执行 SQL 语句,其余查询则直接从缓存中获取数据。当会话关闭时,缓存就会被清除掉。

二级缓存:

也称为全局缓存,它存在于 SqlSessionFactory 中,多个会话之间可以共享缓存数据。当多个会话访问相同的 SQL 查询语句时,只要有一个会话查询到了数据并把结果放入二级缓存中,其他的会话就可以直接从缓存中获取数据。如果缓存中的数据过期或者数据发生变化时,MyBatis 会自动刷新缓存。

注意:

注意:在实际开发中,建议慎用缓存,特别是不要在有大量并发写操作的情况下使用缓存,以免出现数据不一致的问题。另外,需要注意的是,缓存策略是针对单表操作才有意义,多表操作通常不会考虑缓存。

你可能感兴趣的:(mybatis,spring,java)