谈谈Mybatis、Mybatis-Plus与Spring Cache

        大家都知道Mybaits有两级缓存

  1.  一级缓存作用范围默认sqlsession级别,在并发中可能出现脏读,调整为statement可以避免。
  2. 二级缓存作用范围为namespace级别,在多表查询namespace不同时出现脏读,原因是aMapper中的方法获取到联查的数据后,如果被联查的表更新后aMapper是没有更新缓存的。

        SpringCache可以提供key value形式的缓存,可以在根据id查询时以类名加id的形式也可以使用方法名、参数列表缓存在redis中,更新也可以根据类名加id进行更新。

        我对Mybatis-Plus与SpringCache结合的想法:

        Mybatis-Plus默认提供了很多方便查询的方法比如list、selectBatchIds等返回集合的方法,对于这种方法:某个返回集合的方法中根据方法名、参数列表缓存了n个对象,另一个方法中更新了这个集合中某一个对象(数据库中该对象已改变而集合中没有改变),再次查询返回集合的方法时由于缓存没有更新就会出现缓存与数据库数据不一致的脏读问题。要解决这中情况可以指定@CacheEvictallEntries为true,清除所有value中的缓存。

        而跨表的问题也可以当被关联对象更新时 指定关联该对象的方法的缓存 失效。

        总而言之项目中对读多写少的业务关闭Mybatis二级缓存,使用SpringCache,将Mybatis-Plus所有的更新方法中设置allEntries=true

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot整合MyBatis-Plus的步骤如下: 1.引入依赖 在pom.xml文件中加入以下依赖: ```xml <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.x.x</version> </dependency> ``` 2.配置数据源 在application.properties配置文件中配置数据源信息: ```properties spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai spring.datasource.username=root spring.datasource.password=root ``` 3.配置MyBatis-Plus 在application.properties配置文件中加入以下配置: ```properties # MyBatis-Plus配置 mybatis-plus.mapper-locations=classpath:mapper/*.xml mybatis-plus.configuration.map-underscore-to-camel-case=true mybatis-plus.configuration.cache-enabled=false ``` 4.创建实体类 创建实体类,并使用`@TableName`注解指定表名,使用`@TableId`注解指定主键。 ```java @Data @TableName("user") public class User { @TableId(type = IdType.AUTO) private Long id; private String name; private Integer age; private String email; } ``` 5.创建Mapper接口 创建Mapper接口,并继承`BaseMapper`接口,可以直接使用MyBatis-Plus提供的基本数据库操作方法。 ```java public interface UserMapper extends BaseMapper<User> { } ``` 6.使用Mapper接口 在业务逻辑层中使用Mapper接口进行数据库操作,如下所示: ```java @Service public class UserServiceImpl implements UserService { @Autowired private UserMapper userMapper; @Override public List<User> list() { return userMapper.selectList(null); } @Override public User getById(Long id) { return userMapper.selectById(id); } @Override public void save(User user) { userMapper.insert(user); } @Override public void update(User user) { userMapper.updateById(user); } @Override public void delete(Long id) { userMapper.deleteById(id); } } ``` 至此,Spring Boot整合MyBatis-Plus的步骤就完成了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值