在我们的项目中,通常会把数据存储到关系型数据库中,比如Oracle,SQL Server,Mysql等,但是关系型数据库对于并发的支持并不是很强大,这样就会造成系统的性能不佳,而且存储的数据多为结构化数据,对于非结构数据(比如文本)和半结构化数据(比如JSon) 就显得不够灵活,而非关系型数据库则很好的弥补了这两点,  我们通常把读操作频繁的数据写入Redis中,以Key-value的方式存储来提高性能。

Redis支持5种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。以下介绍了.net中操作redis五种数据类型的基本语法。

一、String数据类型的应用场景

1. 简介

string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。

string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。

string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。

2.使用场景

存储简单的键值对,比如我们需要统计某个网站的点击量,关注量、粉丝量等

3. C#使用操作举例

比如现在保存一个Webservice接口的参数,比如地址、用户名、密码、同步时间等信息,我们可以将它在前段页面格式化为JSon字符串,然后通过Ajax传递到服务端进行保存到Redis中,代码如下:

         /// <summary>
/// 保存数据到Redis缓存中
/// GHB BY 2020-06-26
/// </summary>
/// <param name="KeyName">需要保存的键名称,默认保存到redis的第二个数据库中</param>
/// <param name="configInfo">需要保存的配置信息</param>
/// <returns>返回保存的结果</returns>
public string SaveConfigInfoToRedis(string KeyName, string configInfo)
{
using (RedisClient client = new RedisClient("127.0.0.1", , "qd*jy*17ghb", ))
{
if (client == null) return "保存失败!";
if (client.ContainsKey(KeyName))
client.Replace<string>(KeyName, configInfo);
else
client.Set<string>(KeyName, configInfo);
return "保存成功!";
}
}

保存成功后,我们在redis可视化工具中可以看到我们保存的信息为:

如果下次加载数据的时候,我们可以根据Key来读取这个string字符串,然后格式化为Hashtable,在序列化为JOSN格式返回到前端,就可以以表单的形式展示,读取代码如下:

         /// <summary>
/// 从redis缓存中获取数据,转化为相应格式后返回
/// GHB BY 2020-06-26
/// </summary>
/// <param name="KeyName">缓存中的键名称</param>
/// <returns>输入键对应的值信息</returns>
public string LoadConfigFromRedis(string KeyName)
{
using (RedisClient client = new RedisClient("127.0.0.1", , "qd*jy*17ghb", ))
{
if (client == null) return string.Empty;
string configData = client.Get<string>(KeyName);
if (string.IsNullOrWhiteSpace(configData))
return string.Empty;
Hashtable data = JsonConvert.DeserializeObject<Hashtable>(configData);
return JsonConvert.SerializeObject(data); }
}

二、hash(哈希)

1.简介

Redis hash 是一个键值(key=>value)对集合。

Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。

2.使用场景

我们需要灵活的保存一些信息,特别适合保存对象的信息,比如用户信息、配置信息

3.C#使用操作举例

我们现在还是以上面保存接口参数为例,将配置信息保存到Hashtable中,代码如下:

         /// <summary>
/// 操作redis的hashtable类型
/// GHB BY 2020-06-26
/// </summary>
public static void OperateHash()
{
using (RedisClient client = new RedisClient("127.0.0.1", , "qd*jy*17ghb",))
{
Dictionary<string, string> configDic = new Dictionary<string, string>();
configDic.Add("config_IP", "localhost");
configDic.Add("config_Port", "");
configDic.Add("config_serviceName", "orcl");
configDic.Add("config_userName", "DE_POWERPMS");
configDic.Add("config_password", "cppepass");
client.SetRangeInHash("config_info", configDic);
Dictionary<string, string> testHash = client.GetAllEntriesFromHash("config_info");
foreach (var item in testHash)
{
Console.WriteLine("Hash的key为:{0} 值为:{1}", item.Key, item.Value);
}
Console.ReadLine();
}
}

使用redis可视化工具我们可以刚才存储的数据如下:

三、List(列表)

1.简介

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边),可以使用list的push操作将任务存到List,

然后使用pop操作将任务取出执行,在列表头部或者末尾操作数据非常高效,不受队列长度的影响。

列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。

2.使用场景

redis 的 list 数据类型对于大部分使用者来说,是实现队列服务的最经济,最简单的方式。

另外,因为 list 结构的数据查询两端附近的数据性能非常好,所以适合一些需要获取最新数据的场景,比如新闻类应用的 “最近新闻”,获取钱N个用户列表等。

3.C#使用操作举例

对于队列的使用,在此处比如有多个客户端需要打印机打印任务,那么使用队列进行任务的排队,然后按照排队顺序开始打印

对于栈的使用,比如二叉树的遍历,括号的匹配等,我们可以进行先进后出的顺序完成,代码如下:

         /// <summary>
/// 操作redis的List类型
/// GHB BY 2020-06-26
/// </summary>
public static void OperateList()
{
using (RedisClient client = new RedisClient("127.0.0.1", , "qd*jy*17ghb", ))
{
#region List队列操作
client.EnqueueItemOnList("QueueList", "打印任务1"); //入队
client.EnqueueItemOnList("QueueList", "打印任务2");
client.EnqueueItemOnList("QueueList", "打印任务3");
client.EnqueueItemOnList("QueueList", "打印任务4");
long q = client.GetListCount("QueueList");
Console.WriteLine("打印任务按照顺序打印开始");
for (int i = ; i < q; i++)
{
Console.WriteLine("QueueList出队值:{0}", client.DequeueItemFromList("QueueList"));
}
Console.WriteLine("打印任务按照顺序打印完成");
#endregion
#region 栈操作
client.PushItemToList("StackList", "入栈操作1"); //入栈
client.PushItemToList("StackList", "入栈操作2");
client.PushItemToList("StackList", "入栈操作3");
client.PushItemToList("StackList", "入栈操作4");
Console.WriteLine("开始出栈");
long p = client.GetListCount("StackList");
for (int i = ; i < p; i++)
{
Console.WriteLine("StackList出栈值:{0}", client.PopItemFromList("StackList"));
}
Console.WriteLine("出栈完成");
Console.ReadLine();
#endregion
}
}

四.Set(集合)

1.简介

Redis 的 Set 是 string 类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。

集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

2.使用场景

集合主要应用在一些需要求交集、并集、补集这样的场景,比如我们需要求共同好友、共同兴趣爱好、共同关注的微博,限制同一个账号多处登录系统等。

3.C#使用操作举例

比如现在随便举例两个QQ用户为例:QQ用户1和QQ用户2,他们分别有各自的好友,现在我们可以通过集合来获取到他们的共同好友,代码如下:

         /// <summary>
/// 操作redis的Set类型
/// GHB BY 2020-06-26
/// </summary>
public static void OperateSet()
{
using (RedisClient client = new RedisClient("127.0.0.1", , "qd*jy*17ghb", ))
{
#region Set操作
client.AddItemToSet("QQ用户1", "好友A");
client.AddItemToSet("QQ用户1", "好友B");
client.AddItemToSet("QQ用户1", "好友C");
client.AddItemToSet("QQ用户1", "好友D"); client.AddItemToSet("QQ用户2", "好友C");
client.AddItemToSet("QQ用户2", "好友F");
client.AddItemToSet("QQ用户2", "好友G");
client.AddItemToSet("QQ用户2", "好友D");
var setunion = client.GetIntersectFromSets("QQ用户1", "QQ用户2");
Console.WriteLine("QQ用户1和QQ用户2的共同好友为:");
foreach (var item in setunion)
{
Console.WriteLine(item);
}
Console.ReadLine();
#endregion
}
}

运行结果显示他们的共同好友为: 好友C和好友D

五、zset(sorted set:有序集合)

1.简介

在 set 的基础上给集合中每个元素关联了一个分数,往有序集合中插入数据时会自动根据这个分数排序。不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复。

2.使用场景

在集合类型的场景上加入排序就是有序集合的应用场景了。比如根据好友的“亲密度”排序显示好友列表。

3.C#使用操作举例

比如现在有很多主播,每个主播都有粉丝给的礼物,现在需要我们给出礼物数量最多的前三名主播,那么可以使用SortedSet来实现,可以分别给每个主播定义个分数来存储礼物数量,代码如下:

         /// <summary>
/// 操作redis的SortedSet类型
/// GHB BY 2020-06-26
/// </summary>
public static void OperateSortedSet()
{
using (RedisClient client = new RedisClient("127.0.0.1", , "qd*jy*17ghb", ))
{
#region Set操作
client.AddItemToSortedSet("GiftSortedSet", "主播1", );
client.AddItemToSortedSet("GiftSortedSet", "主播2", );
client.AddItemToSortedSet("GiftSortedSet", "主播3", );
client.AddItemToSortedSet("GiftSortedSet", "主播4", );
client.IncrementItemInSortedSet("GiftSortedSet", "主播2", new Random().Next(, ));
Console.WriteLine("礼物数最多的前三名主播为:");
foreach (var item in client.GetRangeWithScoresFromSortedSet("GiftSortedSet",,))
{
Console.WriteLine($"名:{item.Key} 分数:{item.Value}");
}
Console.ReadLine();
#endregion
}
}

运行之后,我们可以看到礼物数前三名的主播了,运行结果如下:

好了,今天的技术分享就到这儿了,如果大家有兴趣,可以共同探讨,QQ:2358643757

c# 操作Redis的五种基本类型总结的更多相关文章

  1. Jedis操作笔记 redis的五种存储类型

    常用数据类型简介: redis常用五种数据类型:string,hash,list,set,zset(sorted set). 1.String类型 String是最简单的类型,一个key对应一个val ...

  2. redis的五种存储类型的具体用法

    String 类型操作 string是redis最基本的类型,而且string类型是二进制安全的.意思是redis的string可以包含任何数据.比如jpg图片或者序列化的对象 $redis-> ...

  3. 最全的Java操作Redis的工具类,使用StringRedisTemplate实现,封装了对Redis五种基本类型的各种操作!

    转载自:https://github.com/whvcse/RedisUtil 代码 ProtoStuffSerializerUtil.java import java.io.ByteArrayInp ...

  4. redis的五种基本数据类型

    redis基本数据类型 redis一共分为5中基本数据类型:String,Hash,List,Set,ZSet 第一种String String类型是包含很多种类型的特殊类型,并且是二进制安全的.比如 ...

  5. spring aop 的五种通知类型

    本文转自:http://blog.csdn.net/cqabl/article/details/46965197 spring aop通知(advice)分成五类: 前置通知[Before advic ...

  6. 学习ActiveMQ(五):activemq的五种消息类型和三种监听器类型

    一.前面我们一直发送的是字符串类型,其实activemq一共支持五种消息类型: 1.String消息类型:发送者:消费者: 1.String消息类型:发送者:消费者: 1.String消息类型:发送者 ...

  7. python操作Redis安装、支持存储类型、普通连接、连接池

    一.python操作redis安装和支持存储类型 安装redis模块 pip3 install redis 二.Python操作Redis之普通连接 redis-py提供两个类Redis和Strict ...

  8. Redis入门到高可用(四)—— Redis的五种数据结构的内部编码

    Redis的五种数据结构的内部编码

  9. jedis操作redis的几种常见方式总结

    Redis是一个著名的key-value存储系统,也是nosql中的最常见的一种,这篇文章主要给大家总结了关于在java中jedis操作redis的几种常见方式,文中给出了详细的示例代码供大家参考学习 ...

随机推荐

  1. Java实现拓扑排序

    1 问题描述 给定一个有向图,求取此图的拓扑排序序列. 那么,何为拓扑排序? 定义:将有向图中的顶点以线性方式进行排序.即对于任何连接自顶点u到顶点v的有向边uv,在最后的排序结果中,顶点u总是在顶点 ...

  2. 2018年全国多校算法寒假训练营练习比赛(第二场)H-了断局

    题目描述 既然是了断局了,大家就随便玩玩数字呗.已知一个数列前十项分别是{0, 1, 1, 2, 4, 7, 13, 24, 44, 81},小G不满足呀:我要更多的数!!!不给就不让你们玩了.小G会 ...

  3. OAuth2.0系列之基本概念和运作流程(一)

    @ 目录 一.OAuth2.0是什么? 1.1 OAuth2.0简介 1.2 OAuth2.0官方文档 二.OAuth2.0原理 2.1 OAuth2.0流程图 三. OAuth2.0的角色 四.OA ...

  4. 游戏开发之UI管理器(跨引擎)

    使用UI管理器的目的 使用单场景与zindex结合的方式管理UI. 能够隐藏底层UI达到优化效果. 很好的组织和管理UI. 跨引擎使用. 管理器分类 根据以往经验我开发了三种类型的管理器,队列管理器, ...

  5. STM32串口打印的那些知识

    常规打印方法 在STM32的应用中,我们常常对printf进行重定向的方式来把打印信息printf到我们的串口助手.在MDK环境中,我们常常使用MicroLIB+fputc的方式实现串口打印功能,即: ...

  6. 【python-opencv】读取、显示、写入图像

    1.读取图像 import cv2 image=cv2.imread("dog2.jpg",1) 说明: 第二个参数是一个标志,它指定了读取图像的方式. cv.IMREAD_COL ...

  7. C# .net framework .net core 3.1 请求参数校验, DataAnnotations, 自定义参数校验

    前言 在实际应用场景中我们常常要对接口的入参进行校验, 例如分页大小是否正确, 必填参数是否已经填写等等. 最简单的实现方式如下图, 这种在实际开发中代码过于冗余, 而且不灵活. 今天介绍一种统一参数 ...

  8. laravel clone后需要做的操作

    首先 安装依赖关系 composer install 第二步 复制配置文件 cp .env.example .env 第三步 创建新的应用程序密钥 php artisan key:generate 第 ...

  9. 【Navicat】Navicat for MongoDBv15.0.6破解版(附破解教程)

    安装包下载链接:https://download.csdn.net/download/l1028386804/12519681 Navicat for MongoDB 15是一款功能十分强大的数据库管 ...

  10. PE文件介绍 (2)-DOS头,DOS存根,NT头

    PE头 PE头由许多结构体组成,现在开始逐一学习各结构体 0X00 DOS头 微软创建PE文件格式时,人们正广泛使用DOS文件,所以微软充分考虑了PE文件对DOS文件的兼容性.其结果是在PE头的最前面 ...