Код: Выделить всё
companyname1:xxx:yyy:zzz
companyname1:yyy
companyname1:qqq:zz:xxx:ppp
companyname1:tttt:zz:qqq
companyName1:iiii:rrrr
companyName1:ppp:ddd:xxx
[... thousands more]
Как мне это организовать, чтобы Redis не приходилось искать по всей база данных? Есть ли способ сгруппировать ключи для каждой компании и потом работать только с этой конкретной группой?
Я изначально делал что-то подобное, но не знаю, имеет ли это право на работу, и самое главное, если это эффективно. Я использую StackExchange.
Код: Выделить всё
var keysToDelete = new List();
var cursor = 0L;
var pageSize = 100;
// pattern = "companyName1::xxx:";
do
{
var redisResult = await _database.ExecuteAsync("SCAN", cursor.ToString(), "MATCH", pattern, "COUNT", pageSize).ConfigureAwait(false);
var result = (RedisResult[])redisResult;
cursor = Convert.ToInt64((string)result[0]);
keysToDelete.AddRange((RedisKey[])result[1]);
}
while (cursor != 0);
Удалить ключи для одной компании, шаблон для удаления может находиться в любом месте ключа
Подробнее здесь: https://stackoverflow.com/questions/786 ... plications