redis: string,list, set, zset, hash,bitmaps, hyperloglog, gepspatial所有的数据类型:每一个指令都要有一个样例

1.String 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。String 类型是二进制安全的,意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。String 类型是 Redis 最基本的数据类型,String 类型的值最大能存储 512MB。> String类型一般用于缓存、限流、计数器、分布式锁、分布式Session。

set key_name "value"
get key_name

2. ListRedis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)一个列表最多可以包含 2^32^ - 1 个元素 (4294967295, 每个列表超过40亿个元素)。> List类型一般用于关注人、简单队列等。

127.0.0.1:6379> lpush list_name "num1"
(integer) 1
127.0.0.1:6379> lpush list_name "num2"
(integer) 2
127.0.0.1:6379> lpush list_name "num3"
(integer) 3
 
lrange list_name 0 2

3. ListRedis列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)一个列表最多可以包含 2^32^ - 1 个元素 (4294967295, 每个列表超过40亿个元素)。> List类型一般用于关注人、简单队列等。

127.0.0.1:6379> sadd set_name "member1"
(integer) 1
127.0.0.1:6379> sadd set_name "member2"
(integer) 1
127.0.0.1:6379> sadd set_name "member3"
(integer) 1
 
 smembers set_name

4.Redis 有序集合和集合一样也是string类型元素的集合且不允许重复的成员。不同的是每个元素都会关联一个==double类型的分数==。redis正是通过分数来为集合中的成员进行从小到大的排序。有序集合的成员是唯一的,但分数(score)却可以重复。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 2^32^ - 1 (4294967295, 每个集合可存储40多亿个成员)。 > Zset类型一般用于排行榜等

127.0.0.1:6379> zadd courses haha
(error) ERR wrong number of arguments for 'zadd' command
127.0.0.1:6379> zadd courses 1 haha
(integer) 1
127.0.0.1:6379> zadd courses 2 heihei
(integer) 1
127.0.0.1:6379> zadd courses 3 lala
(integer) 1
127.0.0.1:6379> zadd courses 4 lala
(integer) 0
127.0.0.1:6379> zadd courses 5 lala
(integer) 0
 
ZRANGE courses 0 10 WITHSCORES

5.Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。类似Java里面的Map\u003CString,Object>\n\n        通过 key(用户ID) + field(属性标签) 就可以操作对应属性数据了,既不需要重复存储数据,也不会带来序列化和并发修改控制的问题

HMSET hpe name "zhangsan" age 18 gender "男" birth 2000-01-01
 HGETALL hpe


Hash类型对应的数据结构是两种:ziplist(压缩列表),hashtable(哈希表)。当field-value长度较短且个数较少时,使用ziplist,否则使用hashtable。
 

6.Redis提供了Bitmaps这个“数据类型”可以实现对位的操作。可以把Bitmaps想象成一个以位为单位的数组, 数组的每个单元只能存储0和1, 数组的下标在Bitmaps中叫做偏移量。

setbit bitmap_map 1 1
 getbit bitmap_name 0

7.求集合中不重复元素个数的问题称为基数问题。HyperLogLog 是用来做基数统计的算法,HyperLogLog 的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定的、并且是很小的。但因为 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素本身,所以 HyperLogLog 不能像集合那样,返回输入的各个元素。\n\n 什么是基数?\n\n 比如数据集 {1, 3, 5, 7, 5, 7, 8}, 那么这个数据集的基数集为 {1, 3, 5 ,7, 8}, 基数(不重复元素)为5。 基数估计就是在误差可接受的范围内快速计算基数。

(integer) 0
127.0.0.1:6379> pfadd course "haha"
(integer) 1
127.0.0.1:6379> pfadd course "heihei"
(integer) 1
127.0.0.1:6379> pfadd course "lala"
(integer) 1
127.0.0.1:6379> pfadd course "haha"
(integer) 0
127.0.0.1:6379> pfcount course
(integer) 3
127.0.0.1:6379> pfmerge course course1
OK
127.0.0.1:6379> pfcount course
(integer) 3

8.Redis 3.2 中增加了对GEO类型的支持。GEO,Geographic,地理信息的缩写。该类型,就是元素的2维坐标,在地图上就是经纬度。redis基于该类型,提供了经纬度设置,查询,范围查询,距离查询,经纬度Hash等常见操作。

127.0.0.1:6379> geoadd china:city 121.47 31.23 shanghai
(integer) 1
127.0.0.1:6379> geoadd china:city 106.50 29.53 chongqing 114.05 22.52 shenzhen 116.38 39.90 beijing
(integer) 3
127.0.0.1:6379> geopos china:city shanghai
1) 1) "121.47000163793563843"
   2) "31.22999903975783553"
127.0.0.1:6379> geopos china:city beijing shanghai km
1) 1) "116.38000041246414185"
   2) "39.90000009167092543"
2) 1) "121.47000163793563843"
   2) "31.22999903975783553"
3) (nil)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

葵因lemon

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值