zoukankan      html  css  js  c++  java
  • stackExchange.redis 实现模糊匹配批量查询

     

    如果使用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 }
    

      

  • 相关阅读:
    python 多个变量赋值
    python标准数据类型
    Python 变量类型
    H3C 扩展ACL与基于时间的ACL
    H3C BGP-filter-policy
    H3C 标准ACL
    H3C BGP实验集合
    H3C IS-IS实验大集合(ipv6)
    H3C ISIS实验大集合(IPv4)
    JS 封装一个显示时间的函数
  • 原文地址:https://www.cnblogs.com/robertyao/p/10346093.html
Copyright © 2011-2022 走看看