若是使用redis的频次较高,那么业务中常常会出现须要根据关键字进行批量查询,因此总结一下StackExchange中使用批量查询的方法(若是数据量很大,那么在redis中模糊查询很耗时,请慎用!)html
初始化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脚本进行模糊查询的批量操做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 }