CRL快速开发框架系列教程五(使用缓存)

时间:2023-03-08 17:14:48

本系列目录

  1. CRL快速开发框架系列教程一(Code First数据表不需再关心)
  2. CRL快速开发框架系列教程二(基于Lambda表达式查询)
  3. CRL快速开发框架系列教程三(更新数据)
  4. CRL快速开发框架系列教程四(删除数据)
  5. CRL快速开发框架系列教程五(使用缓存)
  6. CRL快速开发框架系列教程六(分布式缓存解决方案)
  7. CRL快速开发框架系列教程七(使用事务)
  8. CRL快速开发框架系列教程八(使用CRL.Package)
  9. CRL快速开发框架系列教程九(导入/导出数据)
  10. CRL快速开发框架系列教程十(导出对象结构)
  11. CRL快速开发框架系列教程十一(大数据分库分表解决方案)
  12. CRL快速开发框架系列教程十二(MongoDB支持)
  13. CRL快速开发框架系列教程十三(嵌套查询)

 正文

缓存功能是CRL一大特色,使用起来再简单不过了

从数据库查询,到缓存调用,只是一个方法名的区别,创建维护全自动

如:

从数据库查

var item = Code.ProductDataManage.Instance.QueryItem(b => b.Id==1)

从缓存查

var item = Code.ProductDataManage.Instance.QueryItemFromCache(b=>b.Id==1);

查询多项

var list = Code.ProductDataManage.Instance.QueryFromCache(b => b.Id < 10);

缓存了多少数据

默认是缓存了对应表的所有数据,可以在管理类中重写查询指定缓存哪些数据

还可以按查询指定数据多长时间过期

这里是完整的查询语法,*度很大,注意返回的结果类型

如下表示: 查询ID小于1000,过期时间为10分钟

public class ProductDataManage : CRL.BaseProvider<ProductData>
....
protected override CRL.LambdaQuery.LambdaQuery<ProductData> CacheQuery()
{
return GetLambdaQuery().Where(b => b.Id < 1000).Expire(10);
}

缓存过期了怎么办

如上面指定的是10分钟过期,到10分钟后会再次调用会返回什么,空值?老数据?

当然不是,CRL有缓存管理机制,并且是异步的,缓存创建后,后台线程会监视对应的缓存,如果到达了设定的过期时间

按原SQL查询(如上面重写的CacheQuery方法)重新查询,转换为对应的对象,加载到内存

缓存查找效率

内存查找也是比较费资源的事,特别是数据比较多的情况下,有没有优化的可能?

一般我们会按主键查询某个数据,这种情况比较多,CRL针对这种情况作了优化

如上面查询:

var item = Code.ProductDataManage.Instance.QueryItemFromCache(5);

从所有数据里查询主键为5的数据,看上去为

datas.FindAll(b=>b.Id==5)

实际查询为

if (datas.ContainsKey(id))
{
return datas[id];
}

CRL缓存数据结构是Dictionary<string, TModel>

在按主键查询的情况下,效率会高很多

将查询结果转换为缓存

除了按管理类绑定的缓存外,还可以装任意查询转换为缓存

var query = Code.ProductDataManage.Instance.GetLambdaQuery();
//缓存会按条件不同缓存不同的数据,条件不固定时,慎用
query.Where(b => b.Id < 700);
int exp = 10;//过期分钟
query.Expire(exp);
var list = query.ToList();

这时创建的查询缓存会按参数值不同,缓存N个结果,也是比较好用的

手动维护缓存

缓存一般情况下是自动维护的,也可以手动维护

获取缓存列表

 var caches = CRL.MemoryDataCache.CacheService.GetCacheList();

在页面上显示

 <table border="1" style="width:100%">
<tr>
<td class="auto-style5">KEY</td>
<td class="auto-style2">数据类型</td>
<td class="auto-style3">过期(分)</td>
<td class="auto-style4">上次更新</td>
<td width="50">行数</td>
<td width="200">查询</td>
<td width="100">参数</td>
<td width="40">操作</td>
</tr>
<%
foreach(var item in caches)
{
%>
<tr>
<td class="auto-style5"><%=item.Key %></td>
<td class="auto-style2"><%=item.DataType %></td>
<td class="auto-style3"><%=item.TimeOut %></td>
<td class="auto-style4"><%=item.UpdateTime %></td>
<td><%=item.RowCount %></td>
<td><%=item.TableName %></td>
<td><%=item.Params %></td>
<td><a href="?type=update&key=<%=item.Key %>" target="_blank">更新</a></td>
</tr>
<%} %>
</table>

运行如图

CRL快速开发框架系列教程五(使用缓存)

通过KEY更新缓存

string key = Request["key"];
var a = CRL.MemoryDataCache.CacheService.UpdateCache(key);