java二级缓存作用域_MyBatis开启二级缓存实现过程解析

本文介绍了如何在MyBatis中启用二级缓存,包括修改config.xml配置文件,添加Mapper.xml中的cache标签,以及确保实体类实现Serializable接口。通过这些步骤,可以提升MyBatis应用的性能。
摘要由CSDN通过智能技术生成

MyBatis的一级缓存是sqlSession作用域的,默认开启,执行DML(insert, update, delete)操作后自动删除。

下面介绍一下如何开启MyBatis的二级缓存,作用域为Mapper:

1.修改config.xml配置文件:

这里需要注意一下configuration标签下子标签的顺序。

2.在对应的Mapper.xml中配置二级缓存:

/p>

PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"

"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

insert into user values (#{id}, #{username}, #{password})

很简单,只需要加个cache标签就行了,如以上代码标黄部分。

3.对应的实体类需要实现序列化接口:

package com.wts.entity;

import lombok.AllArgsConstructor;

import lombok.Data;

import lombok.NoArgsConstructor;

import java.io.Serializable;

@Data

@AllArgsConstructor

@NoArgsConstructor

public class User implements Serializable {

private long id;

private String username;

private String password;

}

这样就开启了MyBatis默认的二级缓存。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis提供了两级缓存: - 一级缓存(本地缓存):Mybatis默认开启的,其作用域为SqlSession级别,即在同一个SqlSession中执行相同的查询语句,第一次查询结果会被缓存下来,再次查询相同语句时直接从缓存中获取结果,避免了重复查询数据库,提高了效率。 - 二级缓存(全局缓存):其作用域为整个应用程序,多个SqlSession之间可以共享缓存数据,需要手动开启。当SqlSession执行查询时,查询的数据会被缓存到二级缓存中,再次执行相同的查询时,直接从缓存中获取数据,避免了重复查询数据库,提高了效率。 二级缓存需要注意以下几点: - 对于同一条SQL语句,如果执行过程中有任何的update、insert、delete操作,那么缓存会被清空,下次查询会重新执行SQL语句并缓存结果。 - 对于同一条SQL语句,如果有多个参数,那么不同参数对应的查询结果也会被缓存到不同的缓存中,需要注意查询参数的一致性。 - 二级缓存中存储的是对象的引用地址,而不是对象本身,因此需要保证缓存中的对象不被修改。 一级缓存和二级缓存的区别: - 一级缓存是SqlSession级别的缓存,生命周期比较短,只在SqlSession内有效,而二级缓存是全局的缓存,生命周期比较长,多个SqlSession可以共享缓存数据。 - 一级缓存默认开启二级缓存需要手动开启。 - 一级缓存是基于对象引用的缓存,与数据库同步,而二级缓存是基于数据的缓存,与数据库异步。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值