一、Redis API For .Net 首先,不得不说Redis官方提供了众多的API开发包,但是目前Redis官方版本不支持.Net直接进行连接,需要使用一些第三方的开源类库。目前最流行的就是ServiceStack.Redis这个开源项目,其在GitHub上的下载地址为: ...
一、Redis API For .Net
首先,不得不说Redis官方提供了众多的API开发包,但是目前Redis官方版本不支持.Net直接进行连接,需要使用一些第三方的开源类库。目前最流行的就是ServiceStack.Redis这个开源项目,其在GitHub上的下载地址为:https://github.com/ServiceStack/ServiceStack.Redis
进入下载页面,点击“Download Zip”按钮,即可下载该API包。解压该Zip包后,其实我们所用到的只是其中的几个DLL而已,打开build/release/MonoDevelop文件夹,看到里边还有一个zip包,这里边就是我们所需的DLL了。
再次解压这个Zip包,可以看到其中包含如下图所示的DLL文件,这几个也是我们今天所要引入VS的DLL库,有了它们,我们就可以在程序端和Redis服务端进行对话了,是不是很赞?
这时,我们就可以在VS中新建一个控制台项目,命名为RedisDemo,然后新建一个Lib文件夹用来存放我们的DLL文件,然后添加对这些DLL引用。至此,就是万事俱备只欠东风了,我们接下来会在程序中调用Redis客户端和Redis服务端进行通信,了解Redis API为我们提供的丰富的数据类型。
二、Redis中常用数据类型
由上一篇博客可知,Redis目前提供五种数据类型:string(字符串)、list(链表)、Hash(哈希)、set(集合)及zset(sorted set) (有序集合)。现在,我们一一来看看这五种数据类型的基本使用方法。在开始介绍之前,我们先使用刚刚引入的Redis API建立一个Redis客户端对象,有了这个客户端对象,我们才能和Redis服务端进行通信,且看下面的一行代码。我们需要事先指定好Redis服务端的IP地址和端口号,然后根据这两个信息建立一个RedisClient的对象实例,通过这个实例所带的方法和服务端通信。
static void StringTypeDemo(RedisClient redisClient) { //向Redis中添加一个Key/Value对 redisClient.Set<string>("username", "edisonchou"); //从Redis中读取一个Value值 string userName = redisClient.Get<string>("username"); Console.WriteLine("The value from Redis is {0}", userName); }
运行效果如下:
2.2 Hash 哈希
Hash是一个string 类型的field和value的
映射表。Hash
特别适合存储对象,相对于将对象的每个字段存成单个string 类型。一个对象存储在Hash类型中会占用更少的内存,并且可以更方便的存取整个对象。 第一种方式将用户ID作为查找key,把其他信息封装成一个对象以序列化的方式存储,这种方式的缺点是,
增加了序列化/反序列化的开销,并且在需要修改其中一项信息时,需要把整个对象取回,并且修改操作需要对并发进行保护,引入CAS等复杂问题。 第二种方法是这个用户信息对象有多少成员就存成多少个key-value对儿,用用户ID+对应属性的名称作为唯一标识来取得对应属性的值,虽然省去了序列化开销和并发问题,但是用户ID为重复存储,如果存在大量这样的数据,
内存浪费还是非常可观的。 也就是说,Key仍然是用户ID, value是一个Map,这个Map的key是成员的属性名,value是属性值,这样对数据的修改和存取都可以直接通过其内部Map的Key(Redis里称内部Map的key为field), 也就是通过
key(用户ID) + field(属性标签) 就可以操作对应属性数据了,既不需要重复存储数据,也不会带来序列化和并发修改控制的问题,也就很好的解决了问题。
static void HashTypeDemo(RedisClient redisClient) { redisClient.SetEntryInHash("user", "userinfo", "cool boy"); redisClient.SetEntryInHash("user", "useraccount", "5000"); List<string> keyList = redisClient.GetHashKeys("user"); foreach (string key in keyList) { Console.WriteLine(key); string value = redisClient.GetValueFromHash("user", key); Console.WriteLine("user:{0}:{1}", key, value); } }
2.3 List 链表
Lst是一个链表结构,主要功能是push与pop,获取一个范围的所有的值等,操作中key理解为链表名字。 Redis的List类型其实就是一个每个子元素都是string类型的双向链表,我们可以通过push或pop操作从链表的头部或者尾部添加删除元素,这样List既可以作为栈,又可以作为队列。它即可以支持反向查找和遍历,更方便操作,不过带来了部分额外的内存开销。Redis内部的很多实现,包括发送缓冲队列等也都是用的这个数据结构。
(1)现在我们首先来看看List作为(Stack)栈类型的使用:
那么在VS中如何来Code呢?通过Push与Pop操作Stack
static void QueueTypeDemo(RedisClient redisClient) { redisClient.EnqueueItemOnList("account", "马云"); redisClient.EnqueueItemOnList("account", "马化腾"); redisClient.EnqueueItemOnList("account", "李彦宏"); int length = redisClient.GetListCount("account"); for (int i = 0; i < length; i++) { Console.WriteLine(redisClient.DequeueItemFromList("account")); } }
运行效果如下:
2.4 Set 集合
Set是string类型的无序集合。set是通过hash table实现的,添加,删除和查找,对集合我们可以取并集,交集,差集,可以非常方便的实现如共同关注、共同喜好、二度好友等功能,对上面的所有集合操作,你还可以使用不同的命令选择将结果返回给客户端还是存集到一个新的集合中。
与List比较而言,set对外提供的功能与list类似是一个列表的功能,特殊之处在于set是可以自动排重的,当你需要存储一个列表数据,又不希望出现重复数据时,set是一个很好的选择,并且set提供了判断某个成员是否在一个set集合内的重要接口,这个也是list所不能提供的。
那么在VS中我们使用Set来Code一下,先增加两个Set集合,然后对其进行交集、并集与差集运算:
static void SortedSetTypeDemo(RedisClient redisClient) { redisClient.AddItemToSortedSet("a5", "ffff"); redisClient.AddItemToSortedSet("a5", "bbbb"); redisClient.AddItemToSortedSet("a5", "gggg"); redisClient.AddItemToSortedSet("a5", "cccc"); redisClient.AddItemToSortedSet("a5", "waaa"); List<string> list = redisClient.GetAllItemsFromSortedSet("a5"); foreach (string str in list) { Console.WriteLine(str); } }
运行效果如下:
原标题:【转】NoSQL初探之人人都爱Redis:(2)Redis API与常用数据类型简介
关键词:sql
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:
admin#shaoqun.com
(#换成@)。