redis基础学习二详解大数据

redis数据类型:

1.String类型

设置值:set key value

127.0.0.1:6379> set test 123 
OK

取值:get value

127.0.0.1:6379> get test 
"123“

取值并复制:getset key value

127.0.0.1:6379> getset s2 222 
"111" 
127.0.0.1:6379> get s2

设置/获取多个键值语法: mset key value[key value ….]   mget key [key …]

127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3 
OK 
127.0.0.1:6379> get k1 
"v1" 
127.0.0.1:6379> mget k1 k3 
1) "v1" 
2) "v3"

删除:del key

127.0.0.1:6379> del test 
(integer) 1

数值增减

递增数字:incr key

当存储的字符串是整数时,Redis提供了一个实用的命令INCR,其作用是让当前键值递增,并返回递增后的值。

127.0.0.1:6379> incr num 
(integer) 1 
127.0.0.1:6379> incr num 
(integer) 2 
127.0.0.1:6379> incr num 
(integer) 3 

增加指定的整数:incrby key increment

127.0.0.1:6379> incrby num 2 
(integer) 5 
127.0.0.1:6379> incrby num 2 
(integer) 7 
127.0.0.1:6379> incrby num 2 
(integer) 9

递减数值:decr key

127.0.0.1:6379> decr num 
(integer) 9 
127.0.0.1:6379> decr num 
(integer) 8

减少指定的整数:decrby key decrement

127.0.0.1:6379> decr num 
(integer) 6 
127.0.0.1:6379> decr num 
(integer) 5 
127.0.0.1:6379> decrby num 3 
(integer) 2 
127.0.0.1:6379> decrby num 3 
(integer) -1 

string类型应用:自增主键,例如商品编号,订单号采用string的递增数字特征生成

定义商品编号key:items:id 
192.168.101.3:7003> INCR items:id 
(integer) 2 
192.168.101.3:7003> INCR items:id 
(integer) 3 

2.Map散列类型

设置值:hset key field value

127.0.0.1:6379> hset user username zhangsan  
(integer) 1

取值:hget key field

127.0.0.1:6379> hget user username 
"zhangsan“

设置多个值:hmset key filed value[key filed value….]

127.0.0.1:6379> hmset user age 20 username lisi  
OK

取多个值:hmget key filed[field …]

127.0.0.1:6379> hmget user age username 
1) "20" 
2) "lisi"

获取所有字段值:hgetall key

127.0.0.1:6379> hgetall user 
1) "age" 
2) "20" 
3) "username" 
4) "lisi"

删除:hdel key filed[field]

127.0.0.1:6379> hdel user age 
(integer) 1 
127.0.0.1:6379> hdel user age name 
(integer) 0 
127.0.0.1:6379> hdel user age username 
(integer) 1 

增加数字:hincrby key filed increment

127.0.0.1:6379> hincrby user age 2	#将用户的年龄加2 
(integer) 22 
127.0.0.1:6379> hget user age		#获取用户的年龄 
"22“

判断字段是否存在:hexists key field

127.0.0.1:6379> hexists user age		查看user中是否有age字段 
(integer) 1 
127.0.0.1:6379> hexists user name	查看user中是否有name字段 
(integer) 0

只获取字段名或字段值:hkeys key hvalues key

127.0.0.1:6379> hmset user age 20 name lisi  
OK 
127.0.0.1:6379> hkeys user 
1) "age" 
2) "name" 
127.0.0.1:6379> hvals user 
1) "20" 
2) "lisi"

应用:存储商品信息

商品字段:【商品id、商品名称、商品描述、商品库存、商品好评】

定义商品信息的key:商品1001的信息在 Redis中的key为:[items:1001]

存储商品信息

192.168.101.3:7003> HMSET items:1001 id 3 name apple price 999.9 
OK

获取商品信息:

192.168.101.3:7003> HGET items:1001 id 
"3" 
192.168.101.3:7003> HGETALL items:1001 
1) "id" 
2) "3" 
3) "name" 
4) "apple" 
5) "price" 
6) "999.9" 

3.list集合类型

首先了解下Arraylist和linklist的区别:

Arraylist是使用数组来存储数据,特点:查询快、增删慢

Linkedlist是使用双向链表存储数据,特点:增删快、查询慢,但是查询链表两端的数据也很快。

Redis的list是采用来链表来存储的,所以对于redis的list数据类型的操作,是操作list的两端数据来操作的。

向列表左边增加元素:lpush key value[value…]

127.0.0.1:6379> lpush list:1 1 2 3 
(integer) 3

向列表右边增加元素:rpush key value[value…]

127.0.0.1:6379> rpush list:1 4 5 6 
(integer) 3

查看列表:lrang key start stop

LRANGE命令是列表类型最常用的命令之一,获取列表中的某一片段,将返回start、stop之间的所有元素(包含两端的元素),索引从0开始。索引可以是负数,如:-1”代表最后边的一个元素

127.0.0.1:6379> lrange list:1 0 2 
1) "2" 
2) "1" 
3) "4" 
 
127.0.0.1:6379> lrange list1 0 -1

从列表两端弹出元素:lpop key rpop key

LPOP命令从列表左边弹出一个元素,会分两步完成:第一步是将列表左边的元素从列表中移除第二步是返回被移除的元素值。

127.0.0.1:6379> lpop list:1 
"3“ 
127.0.0.1:6379> rpop list:1 
"6“

设置指定索引的元素值:lset key index value

127.0.0.1:6379> lset l:list 2 2

获得指定元素的值:lindex key index

127.0.0.1:6379> lindex l:list 2 
"2"

查找元素:lrang key start stop

127.0.0.1:6379> lrange l:list 0 -1 
1) "6" 
2) "5" 
3) "0" 
4) "2"

将元素从一个列表转移到另一个列表中:rpoplpush source destination

127.0.0.1:6379> rpoplpush list newlist  
"1" 
127.0.0.1:6379> lrange newlist 0 -1 
1) "1" 
127.0.0.1:6379> lrange list 0 -1 
1) "3" 
2) "4" 
3) "2"

应用:商品评论列表

在Redis中创建商品评论列表,用户发布商品评论,将评论信息转成json存储到list中,用户在页面查询评论列表,从redis中取出json数据展示到页面。

定义商品评论列表key:商品编号为1001的商品评论key【items: comment:1001】

192.168.101.3:7001> LPUSH items:comment:1001 '{"id":1,"name":"商品不错,很好!!","date":1430295077289}'

4.Set集合类型

增加元素:sadd key member[member]

127.0.0.1:6379> sadd set a b c 
(integer) 3 
127.0.0.1:6379> sadd set a 
(integer) 0

删除元素:srem key member[member…]

127.0.0.1:6379> srem set c d 
(integer) 1

获得集合中的所有元素:smembers key

127.0.0.1:6379> smembers set 
1) "b" 
2) "a”

判断元素是否在集合中:sismember key member

127.0.0.1:6379> sismember set a 
(integer) 1 
127.0.0.1:6379> sismember set h 
(integer) 0

获得集合中的元素个数:scard key

127.0.0.1:6379> smembers setA  
1) "1" 
2) "2" 
3) "3" 
127.0.0.1:6379> scard setA  
(integer) 3

从集合中弹出一个元素:spop key

注意:由于集合是无序的,所有SPOP命令会从集合中随机选择一个元素弹出

127.0.0.1:6379> spop setA  
"1“ 

SortedSet有序集合,可排序,且唯一

Sortedset和set的不同之处,是会给set中的元素添加一个分数,然后通过这个分数进行排序。

增加元素:zadd key score member[score member]

向有序集合中加入一个元素和该元素的分数,如果该元素已经存在则会用新的分数替换原有的分数。返回值是新加入到集合中的元素个数,不包含之前已经存在的元素。

127.0.0.1:6379> zadd scoreboard 80 zhangsan 89 lisi 94 wangwu  
(integer) 3 
127.0.0.1:6379> zadd scoreboard 97 lisi  
(integer) 0

获取元素的分数:zscore key member

127.0.0.1:6379> zscore scoreboard lisi  
"97"

删除元素:zrem key member[member…]

移除有序集key中的一个或多个成员,不存在的成员将被忽略。当key存在但不是有序集类型时,返回一个错误

127.0.0.1:6379> zrem scoreboard lisi 
(integer) 1

获得排名在某个范围的元素列表

zrange key start stop:按照元素分数从小到大的顺序返回索引从start到stop之间的所有元素(包含两端的元素)

127.0.0.1:6379> zrange scoreboard 0 2 
1) "zhangsan" 
2) "wangwu" 
3) "lisi“

zrevrange key start stop:按照元素分数
从大到小的顺序返回索引从start到stop之间的所有元素(包含两端的元素)

127.0.0.1:6379> zrevrange scoreboard 0 2 
1) " lisi " 
2) "wangwu" 
3) " zhangsan “ 

如果需要获得元素的分数的可以在命令尾部加上WITHSCORES参数

127.0.0.1:6379> zrange scoreboard 0 1 WITHSCORES 
1) "zhangsan" 
2) "80" 
3) "wangwu" 
4) "94"

获取元素的排名

从小到大:ZRANK key member

127.0.0.1:6379> ZRANK scoreboard lisi  
(integer) 0

从大到小:ZREVRANK key member

127.0.0.1:6379> ZREVRANK scoreboard zhangsan  
(integer) 1

获得指定分数范围的元素:ZRANGEBYSCORE key min max [WITHSCORES] [LIMI Toffset count]

127.0.0.1:6379> ZRANGEBYSCORE scoreboard 90 97 WITHSCORES 
1) "wangwu" 
2) "94" 
3) "lisi" 
4) "97" 
127.0.0.1:6379> ZRANGEBYSCORE scoreboard 70 100 limit 1 2 
1) "wangwu" 
2) "lisi"

增加某个元素的分数:zincrby key increment member

返回值时更改后的分数

127.0.0.1:6379> ZINCRBY scoreboard 4 lisi  
"101“

获得集合中元素的数量:zcard key

127.0.0.1:6379> ZCARD scoreboard 
(integer) 3

获得指定分数范围内的元素个数:zcount key min max

127.0.0.1:6379> ZCOUNT scoreboard 80 90 
(integer) 1

按照排名范围删除元素:ZREMRANGEBYRANK key start stop

127.0.0.1:6379> ZREMRANGEBYRANK scoreboard 0 1 
(integer) 2  
127.0.0.1:6379> ZRANGE scoreboard 0 -1 
1) "lisi"

按照分数范围删除元素:ZREMRANGEBYSCORE key min max

127.0.0.1:6379> zadd scoreboard 84 zhangsan	 
(integer) 1 
127.0.0.1:6379> ZREMRANGEBYSCORE scoreboard 80 100 
(integer) 1

应用:商品销售排行榜

需求:根据商品销售量对商品进行排行显示

思路:定义商品销售排行榜(sorted set集合),Key为items:sellsort,分数为商品销售量。

写入商品销售量:商品编号1001的销量是9,商品编号1002的销量是10

192.168.101.3:7007> ZADD items:sellsort 9 1001 10 1002

商品编号1001的销量加1

192.168.101.3:7001> ZINCRBY items:sellsort 1 1001

商品销量钱10排名

192.168.101.3:7001> ZRANGE items:sellsort 0 9 withscores

原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/tech/bigdata/9062.html

(0)
上一篇 2021年7月19日 09:10
下一篇 2021年7月19日 09:10

相关推荐

发表回复

登录后才能评论