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)