Bootstrap

StackExchange.redis 实现模糊匹配批量查询

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Helloantoherday/article/details/81286685
如果使用redis的频次较高,那么业务中经常会出现需要根据关键字进行批量查询,所以总结一下StackExchange中使用批量查询的方法(如果数据量很大,那么在redis中模糊查询很耗时,请慎用!)

初始化redis连接对象: 

string _connectionString = ConfigurationManager.ConnectionStrings["RedisConnectionString"].ConnectionString;
ConnectionMultiplexer _connMultiplexer = ConnectionMultiplexer.Connect(_connectionString);
IDataBase _db = _connMultiplexer.GetDatabase(db);

通过 keys或scan查找出匹配的key,StackExchange.Redis 中调用 keys/scan/size/flush/save/集群 等命令须使用 IServer 对象

​var _server = _connMultiplexer.GetServer(_connMultiplexer.GetEndPoints()[0]); //默认一个服务器
var pattern = "keyword*";
var keys = _server.Keys(database: _db.Database, pattern: pattern); //StackExchange.Redis 会根据redis版本决定用keys还是   scan(>2.8) 
return _db.KeyDelete(keys.ToArray()); //删除一组key


如果数据量很大(比如几十万个key),为了提高效率,可以通过Lua脚本进行模糊查询的批量操作

var pattern = "keyword*";
var redisResult = _db.ScriptEvaluateAsync(LuaScript.Prepare(
                //Redis的keys模糊查询:
                " local res = redis.call(‘KEYS‘, @keypattern) " +
                " return res "), new { @keypattern = pattern });
 
if (!redisResult.IsNull) {
  _db.KeyDelete((string[])redisResult);  //删除一组key

————————————————
版权声明:本文为CSDN博主「行者僧」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/Helloantoherday/article/details/81286685

;