0前言
本篇文章介绍redis的五大基本数据类型和三种特殊数据类型的操作方法和使用场景
1.String
//在name字符串种追加zhangsan
append name zhangsan
//age+1
incr age
//age-1
decr age
//age+10
incrby age 10
//age-10
decr age 10
//截取name从0到3的字符串
getrange name 0 3
//显示name的全部字符串
getrange name 0 -1
//替换指定位置开始的字符串
setrange name 1 xx
//setex(set with expire)#设置过期时间
setex name 30 hello
//setnx(set if not exist)不存在设置(在分布式锁种会常常使用!)
//如果name不存在,则创建,如果存在,则创建失败
setnx name zhangsan
//批量创建 k1,k2k3
//mset是一个原子性的操作,要么一起成功,要么一起失败
mset k1 v1 k2 v2 k3 v3
//批量获取k1,k2,k3
mget k1 k2 k3
//先get,再set
//如果不存在值,则返回nil,如果存在值,获取原来的值,并设置新的值
getset name zhangsan
String使用场景value除了是我们的字符串还可以是我们的数字
- 计数器
- 统计多单位的数量
2.List
//将一个或多个值插入到列表头部
LPUSH list one
//获取list种所有值
LRANGE list 0 -1
//通过区间获取list具体的值
LRANGE list 0 1
//将一个或多个值插入到列表尾部
Rpush list right
//移除list的头部元素
Lpop list
//移除list的尾部元素
Rpop list
//通过下标获得list中的某一个值
lindex list 1
//返回list的长度
Llen list
//移除list集合中指定个数value,匹配个数
lrem list 1 one
//通过下标截取指定的长度,改变原list
ltrim mylist 1 2
//移除列表的最后一个元素,将他移动到新的列表中
rpoplpush mylist myotherlist
//将list中第0个元素替换为item
lset list 0 item
//在mylist的world元素前面增加一个new元素
linsert mylist before world new
//在mylist的world元素后面增加一个new元素
linsert mylist after world new
总结:
实际上是一个链表,before Node after,left,right都可以插入值
如果key不存在,创建新的链表
如果key存在,新增内容
如果移除了所有值,空链表,也不存在
在两边插入或者改动值,效率最高
消息排队!消息队列Lpush Rpop,栈
3.Set(集合)
//set集合中添加元素
sadd myset hello
//查看指定set的所有值
smembers myset
//判断某一个值是否在set集合中,是返回1,否返回0
sismember myset world
//获取set集合中的内容元素个数!
scard myset
//移除set集合中的指定元素
srem myset hello
//随机抽选出一个元素
srandmember myset
//随机抽选出两个元素
srandmember myset 2
//随机删除一些set集合中的元素
spop myset
//将一个指定的值,移动到另外一个set集合
smove myset myset2 HelloWorld
//差集
sdiff set1 set2
//交集
sinter set1 set2
//并集
sunion set1 set2
set中的值是不可重复的
应用:
微博:共同关注/共同好友,推荐好友
4.Hash()
Map集合。本质和String类型没有太大区别,还是一个简单的key -value。
//在myhash中set一个key-value
hset myhash key1 hello
//get一个key-value
hget myhash key1
//set多个key-value
hmset myhash key1 hello key2 world
//get多个key-value
hmget myhash key1 key2
//get 全部的key-value
hgetall myhash
//删除指定的key及value
hdel myhash key1
//获取hash表的字段数量
hlen myhash
//判断hash中指定的key是否存在
hexists myhash key1
//获得所有key
hkeys myhash
//获得所有value
hvals myhash
hash存放变更的数据user name age,用户信息等,hash更适合对象的存储
5.Zset(有序集合)
//在1的位置上添加一个one
zadd myset 1 one
//在salary里面新增三个用户
zadd salary 500 zhangsan 2500 lisi 5000 xiaohong
//按照salary升序排序
zrangebyscore salary -inf +inf
//降序排序
zrevrange salary 0 -1
//显示小于2500的并附带score
zrangebyscore salary -inf 2500 withscores
//移除xiaohong
zrem salary xiaohong
//获取有序集合中的个数
zcard salary
//获取指定区间成员的数量
zcount myset 500 5000
set排序 存储班级成绩表,工资表排序
带权重判断
排行榜应用实现。取TopN
6.geospatial
地理位置模型
//添加一个城市信息
//参数 key 维度、经度、名称
geoadd china:city 116.40 39.00 beijing
//获取指定的城市的精度和维度
geopos china:city beijing
//查看北京到上海的距离
geodist china:city beijing shanghai
//以千米为单位查看北京到上海的距离
geodist china:city beijing shanghai km
//以110,30为中心,寻找方圆1000km内的城市
georadius china:city 110 30 1000 km
//以110,30为中心,寻找方圆500km内的城市,并显示距离
georadius china:city 110 30 500 km withdist
//以110,30为中心,寻找方圆500km内的城市,并显示经纬度
georadius china:city 110 30 500 km withcoord
//找出位于指定元素周围的元素
georadiusbymember china:city beijing 1000 km
//将二维的经纬度转换为一维的字符串
geohash china:city beijing shanghai
GEO底层的实现原理其实就是Zset!我们可以使用Zset命令来操作geo
//删除北京这个元素
zrem china:city beijing
7.Heperloglog
什么是基数
A{1,3,5,7,8,7} B{1,3,5,,7,8}
基数(不重复元素的数量)
Hyperloglog技术统计的算法
//创建元素mykey和mykey2
pfadd mykey a b c d e f g h i j
pfadd mykey2 i j z x c v b n m
//查看mykey中有多少个元素
pfcount mykey
//把mykey3作为mykey和mykey2的并集
pfmerge mykey3 mykey mykey2
8.Bitmaps
位存储
统计用户信息
高效
//统计一周打卡次数
//0~6分别代表周一至周日
//第一个参数表示位置,第二个参数0/1
127.0.0.1:6379> setbit sign 0 1
(integer) 0
127.0.0.1:6379> setbit sign 1 0
(integer) 0
127.0.0.1:6379> setbit sign 2 0
(integer) 0
127.0.0.1:6379> setbit sign 3 1
(integer) 0
127.0.0.1:6379> setbit sign 4 1
(integer) 0
127.0.0.1:6379> setbit sign 5 0
(integer) 0
127.0.0.1:6379> setbit sign 6 0
(integer) 0
//获取第四位的值
127.0.0.1:6379> getbit sign 3
(integer) 1
//获取第六位的值
127.0.0.1:6379> getbit sign 6
(integer) 0
//统计0~6位里有多少个1
127.0.0.1:6379> bitcount sign
(integer) 3