Redis 根据Key模糊批量查询数据

前言

经常会有这样一种业务逻辑,就是需要根据Redis中Key的规则,模糊查询对应的数据,当数据量少时,利用常规的命令也能满足需求,但是数据量大时,就会导致堵塞,就算是采用不堵塞的函数,如果数据需要显示的话,显示结果的时间也比较慢,用户体验不好。

Lua脚本

Redis 自2.6.0版本之后,就内置了Lua脚本,可以执行相关Lua脚本,提高操作效率;具体Lua脚本大家百度自行学习,不难;

应用:

这里记录的是在C#中的简单使用,其他语言也类似;

引用的包StackExchange.Redis,  我这里用的是2.0.601的版本;

代码实例:

 

 如上图,这个方法是根据一个模糊Key值进行查询,中间字符串拼接的字符串就是lua脚本,使用redis.call()方法来执行Redis对应的指令;

然后将结果解析返回到前台;其他变量都是一些封装,其中db这个类型是IDatabase类型,相信用redis的小伙伴看见这个类型就明白了。

总结:

亲测这样的速度比直接执行循环get,或执行mget指令效率好很多, 以上只是记录一个思路,lua脚本可以做很多事,不仅仅是查询,增删改查都可以,特别对批量操作,效率很不错。

关注公众号,每周更新至少两篇关于.NetCore相关文章

 

 

相关文章

项目中经常遇到CSV文件的读写需求,其中的难点主要是CSV文件...
简介 本文的初衷是希望帮助那些有其它平台视觉算法开发经验的...
这篇文章主要简单记录一下C#项目的dll文件管理方法,以便后期...
在C#中的使用JSON序列化及反序列化时,推荐使用Json.NET——...
事件总线是对发布-订阅模式的一种实现,是一种集中式事件处理...
通用翻译API的HTTPS 地址为https://fanyi-api.baidu.com/api...