查询缓存

相关方法:

缓存对象

缓存适配(Redis缓存)

默认情况下ORM*gcache.Cache缓存对象提供的是单进程内存缓存,虽然性能非常高效,但是只能在单进程内使用。如果服务如果采用多节点部署,多节点之间的缓存可能会产生数据不一致的情况,因此大多数场景下我们都是通过Redis服务器来实现对数据库查询数据的缓存。*gcache.Cache对象采用了适配器设计模式,可以轻松实现从单进程内存缓存切换为分布式的缓存。使用示例:

使用示例

示例代码

执行后输出结果为(测试表数据结构仅供示例参考):

  1. 执行两次One方法数据查询,第一次走了SQL查询,第二次直接使用到了缓存,SQL没有提交到数据库执行,因此这里只打印了一条查询SQL,并且两次查询的结果也是一致的。
  2. 注意这里为该查询的缓存设置了一个自定义的名称vip-user,以便于后续清空更新缓存。如果缓存不需要清理,那么可以不用设置缓存名称。
  3. 随后再执行One方法数据查询,这时重新缓存新的数据。