您的位置:首页 > 数据库 > Redis

Redis之五种数据类型

2017-09-29 13:22 316 查看
Redis 是一个开源的,先进的key-value持久化产品。它通常被称为数据结构服务器,它的值可以是字符串(string),哈希(map),列表(list),集合(sets)和有序集合(stored sets)等类型。可以在这些类型上面做一些原子操作,如字符串追加,增加hash里面的值,添加元素到列表,计算集合的交集、并集和差集。或者区有序集合中排名最高的成员

为了取得好的性能,redis是一个内存型数据库.

本章节,我们主要讲一下redis的五种数据类型:

一.String类型

string 是最基本的类型,而且string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象。从内部实现来看其实string可以看做byte数组,最大上限是1G字节。string类型数据操作指令简介

1.set keyvalue 设置key对应类型string类型的值,返回1表示成功,0失败。

2.setnx keyvalue 如果key不存在,设置key对应string类型的值。如果key已经存在,返回0。

3.get key 获取key对应的string值,如果key不存在返回nil

4.getsetkey value 先获取key的值,再设置key的值。如果对应key不存在,则对应返回nil

5.mget key1 key2 ..  keyN valueN一次设置多个key的值,成功返回1,表示所有的值都已经设置了,失败返回0表示没有任何值被设置、

6.mget key1 value1 ... keyN valueN 一次可设置多个key的值,成功返回1表示所有的值都已经设置了,失败返回0表示没有任何值被设置

7.msetnxkey1 value1 ... keyN valueN 一次设置多个多个key的值,但是不会覆盖已经存在的key incrkey 对 key的值做++操作,并返回新的值

注意 incr 一个不是int的value会返回错误,incr一个不存在的key,设置key值为1.

8.decr key : 对key的值做--操作,decr一个不存在key,则设置key值为-1.

9.incrbykey intrger 对key加上指定值,key不存在时候会设置key,并认为原来的value是0

10.decrbykey integer 对key减去指定值。decrby完全是为了可读性。我们完全可以通过incrby一个负值来实现同样的效果,反之一样。

二.hash类型

hash是一个string类型的field和value的映射表,添加,删除操作都是o(1)(平均)hash特别适合用于存储对象,相对于将对象的每一个字段存成单个string类型。将一个对象存储在hash类型中会占用更少的内存,并且可以方便的存储整个对象,省内存的原因是新建一个hash对象时开始用zipmap(又称为small hash)来存储的。这个zipmap其实并不是hashtable ,但是zipmap相比正常的hash实现可以节省不少的hash本身需要的一些元数据存储开销。尽管zipmap的添加,删除,查找都是o(n),但是由于一般对象的field数量都不太多。所以使用zipmap也是很快的,也就是说添加删除平均还是o(1)如果field或者value的大小超出了一定限制后,redis会在内部自动将zipmap替换成正常的hash实现,这个限制可以在配置文件中指定。

hash类型数据操作指令简介

1.hset keyfield value 设置hash field为指定值,如果key 不存在,则创建

2.hget keyfield 可以获取指定的hash field 

3.hmget keyfield1 .... fieldN获取全部指定的hash field 

4.hmset keyfield1 value1 ... filedN valueN同时设置hash的多个field

5.hincrbkey field intrger 将指定hashfield加上指定值,成功返回hashfiled

6.hexistskey field 检测指定的field是否存在.hdelkey field删除指定的hash field。

7.hlen key 返回指定hash的field数量。hkey key 返回所有的field

8.hlen key 返回hash的所有value。

9.hgetall返回hash的所有的filed和value。

三.List类型

list是一个链表结构,可以理解为一个每个子元素都是string类型的双向链表。主要成功时push,pop,获取一个范围的所有值等。操作中key理解为链表的名字,list类型数据操作指令简介

1.lpush keystring 在key对应的list的头部添加字符串元素,返回1表示成功,0表示key存在且不是list类型

2.rpush keystring 在key对应的list尾部添加字符串元素

3.llen key 返回对应的list的长度 ,如果key 不存在返回0 ,如果key对应的类型不是list返回错误。

4.lrangekey start end 返回指定区间内的元素,下标从0开始,负值表示从后面计算,-1表示倒数第一个元素。key不存在返回空列表。

5.ltrim keystart end 截取list指定区间元素,成功返回1,key不存在返回错误

6.lset keyindex value 设置list中指定的下标的元素值,成功返回1,key 或者下标不存在返回错误。

7.lrem  keycount value 从list的头部(count正数)或尾部(count负数)删除一定数量(count)匹配的value 元素,返回删除元素的个数,count为0的时候全部删除

8.lpop key 从list的头部删除并返回删除元素,如果key对应list不存在或者是空返回nil,如果key对应值不是list返回错误

9.rpop key 从list 的尾部删除并返回删除元素

10.blpopkey1 ... keyN timeout 从左到右扫描,返回对第一个非空list进行lpop操作并返回,比如blpop list1 list2 list3 0 ,如果list不存在list2,list3都是非空则list2做lpop并返回从list2中删除的元素,如果所有的list都是空或不存在,怎会阻塞timeout秒,timeout为0表示一直阻塞。当阻塞时,如果有client对key1....keyN中的任意key进行push操作,则第一在这个key上被阻塞的client会立即返回。如果超过时发生,则返回nil。有点像unix的select或者poll。

11.brpop同blpop,一个是从头部开始删除,一个是从尾部删除。

四.set类型

set是无序集合,最大可以包含(2的32次方-1)个元素。set的时通过hash table 实现的,所以添加,删除,查找的复杂度都是o(1)hash table 会随着添加或者删除自动调整大小。需要注意的是hash table 大小需要同步(获取写锁)会阻塞其它读写操作。可能不久后就会改用跳表(skip)来实现。跳表已经在sorted sets中使用了,关于
set 集合类型除了基本的添加删除操作,其它有用的操作还包含集合的取并集(union),交集(intersection),差集(difference)。通过这些操作可以很容易的实现 SNS 中的好友推荐和 blog 的 tag 功能。

 set类型数据操作指令简介

1.      sadd keymember 添加一个string元素到key对应set集合中,成功返回1,如果元素以及在集合中则返回0,key对应的set不存在则返回错误。

2.      srem keymember 从key对应set中移除指定元素,成功返回1,如果member在集合中不存在或者key不存在返回0,如果key对应的不是set类型的值返回错误。

3.      spop key 删除并返回key对应set中随机的一个元素,如果set是空或者key不存在返回 nil。

4.      srandmemberkey 同spop,随机取set中的一个元素,但是不删除元素。

5.      smovesrckey dstkey member 从srckey对应set中移除member并添加到dstkey对应set中,整个操作是原子的。成功返回1,如果member在srckey中不存在返回0,如果key不是set 类型返回错误。

6.      scard key 返回set的元素个数,如果set是空或者key不存在返回0。

7.      sismemberkey member 判断member是否在set中,存在返回1,0表示不存在或者key不存在。

8.      sinterkey1 key2 …… keyN 返回所有给定key的交集。

9.      sinterstoredstkey key1 ....... keyN 返回所有给定key的交集,并保存交集存到dstkey下。

10.    sunionkey1 key2 ...... keyN 返回所有给定key的并集。

11.    sunionstoredstkey key1 ...... keyN 返回所有给定key的并集,并保存并集到dstkey下。

12.    sdiffkey1 key2 ...... keyN 返回所有给定key的差集。

13.    sdiffstoredstkey key1 ...... keyN 返回所有给定key的差集,并保存差集到dstkey下。

14.    smemberskey 返回key对应set的所有元素,结果是无序的。

五.sorted set

1.      add keyscore member 添加元素到集合,元素在集合中存在则更新对应score。

2.      zrem keymember 删除指定元素,1 表示成功,如果元素不存在返回 0。

3.      zincrbykey incr member 增加对应 member 的 score 值,然后移动元素并保持skip list 保持有序。返回更新后的 score 值。

4.      zrank keymember 返回指定元素在集合中的排名(下标),集合中元素是按 score 从小到大排序的。

5.      zrevrankkey member 同上,但是集合中元素是按score 从大到小排序。

6.      zrangekey start end 类似 lrange 操作从集合中去指定区间的元素。返回的是有序结果

7.      zrevrangekey start end 同上,返回结果是按 score 逆序的。

8.      zrangebyscorekey min max 返回集合中 score 在给定区间的元素。

9.      zcountkey min max 返回集合中 score 在给定区间的数量。

10.    zcard key 返回集合中元素个数。

11.    zscorekey element 返回给定元素对应的 score。

12.    zremrangebyrankkey min max 删除集合中排名在给定区间的元素。

13.    zremrangebyscorekey min max 删除集合中 score 在给定区间的元素。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息