1.3. Spring Cache 注解


@Cacheable@CacheEvict 注释向方法添加缓存功能。

@Cacheable
在缓存中存储返回值。
@CacheEvict
通过删除旧条目来控制缓存大小。

@Cacheable

Book 对象作为示例,如果您在使用 BookDao#findBook (Integer bookId) 等方法从数据库加载后缓存每个实例,您可以添加 @Cacheable 注解,如下所示:

@Transactional
@Cacheable(value = "books", key = "#bookId")
public Book findBook(Integer bookId) {...}

在前面的示例中,当 findBook (Integer bookId) 返回 Book 实例时,它将存储在名为 books 的缓存中。

@CacheEvict

使用 @CacheEvict 注释,您可以指定是否要驱除整个 缓存,或者仅驱除与特定 #bookId 匹配的条目。

整个缓存驱除

使用 @CacheEvictdeleteAllBookEntries () 方法添加 allEntries 参数,如下所示:

@Transactional
@CacheEvict (value="books", key = "#bookId", allEntries = true)
public void deleteAllBookEntries() {...}

基于条目的驱除

使用 @CacheEvict 标注 deleteBook (Integer bookId) 方法,并指定与该条目关联的密钥,如下所示:

@Transactional
@CacheEvict (value="books", key = "#bookId")
public void deleteBook(Integer bookId) {...}
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。 了解我们当前的更新.

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

Theme

© 2026 Red Hat
返回顶部