澄清EF Plus的具体内容

时间:2018-04-30 17:30:51

标签: entity-framework entity-framework-plus entity-framework-extensions

如果我有一个服务请求表,我在其上运行以下代码:

var serviceRequest = await _ctx.ServiceRequests.DeferredAny(t => t.Id == h.Id).FromCacheAsync("ServiceRequestByID");

这与保存此查询是否相同:

SELECT * FROM ServiceRequests WHERE ID = 12345

或者说:

SELECT * FROM ServicesRequests(然后从新缓存的数据中找到id 12345)。

换句话说,在使用上面的代码行时,究竟缓存了什么?如果我稍后带着一个新ID回来,那么它会查询缓存还是去数据库,因为它第一次只保存了第一个ID的记录?

1 个答案:

答案 0 :(得分:1)

结果已缓存。

在您的情况下,布尔值结果被缓存而不是实体。

如果使用不同的ID进行查询,它将查询数据库并缓存结果以及其他结果