我正在.Net Core
使用 RediSearch 开发一个网络应用程序。以前我使用过应用内内存缓存,但我必须将其更改为分布式缓存。问题是,Web 应用程序具有非常复杂的搜索,必须从缓存中处理。我虽然我只是将缓存移动到Redis
并且必须过滤Linq
将保持与应用内内存缓存相同,但如果您在 Redis 中有 500K+ 条目,则在同一主机上使用 docker 映像大约需要 4 秒才能加载这些进入变量,所以这不是一个选项。
我现在已经实现RediSearch
了NRediSearch
似乎可以很好地处理负载的方法。我现在遇到的问题是,我搜索了多个位置字段。
例子
class Item{
public int Id {get;set;}
public int CountyId {get;set;}
public int CityId {get;set;}
}
class Location{
public int LocationId {get;set;}
public bool IsCounty {get;set;}
}
我需要将以下Linq
命令翻译成RediSearch
public List<Item> Search(List<Location> location){
var result = items.Where(i => location.Any(l => l.IsCounty && l.Id == i.CountyId) || location.Any(l => !l.IsCounty && i.CityId == l.Id))
}
我已阅读RediSearch
文档,但尚未找到任何答案。由于排序,我必须在一次搜索中执行此操作。