Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及 zset(sorted set:有序集合)。

一、Redis 数据类型-STRING

1、常用命令

SET key value                #存
GET key #取
Del key #删除key
INCR key #自增key对应的value的值,增量为1
INCRBY key increment #自增key对应的value的值,增量为 increment
DECR key #递减key对应的value的值,增量为-1
getset key value #命令用于设置指定 key 的值,并返回 key 的旧值。
  当 key 没有旧值时,即 key 不存在时,返回 nil
  当 key 存在但不是字符串类型时,返回一个错误

2、实例

实例1: set key value

D:\Redis>redis-cli.exe -h 127.0.0.1 -p 6379
127.0.0.1:6379> set set:test 1 # 返回ok 说明成功
OK
127.0.0.1:6379> set set:test1 1
OK
127.0.0.1:6379> set set:test2 1
OK
127.0.0.1:6379> keys * # 列出所有的key
1) "set:test"
2) "set:test2"
3) "set:test1"
127.0.0.1:6379> set system:user 1
OK
127.0.0.1:6379> set system:role 1
OK
127.0.0.1:6379> set system:group 1
OK
127.0.0.1:6379> keys *
1) "system:role"
2) "set:test"
3) "set:test1"
4) "set:test2"
5) "system:group"
6) "system:user"
127.0.0.1:6379>

说明:

  set system:user 1
  key就是 system:user ;value就是1

实例2:切库

127.0.0.1:6379> select 1
OK
127.0.0.1:6379[1]> keys *
(empty list or set)
127.0.0.1:6379[1]> select 0
OK
127.0.0.1:6379> keys *
1) "system:role"
2) "set:test"
3) "set:test1"
4) "set:test2"
5) "system:group"
6) "system:user"
127.0.0.1:6379>

在 redis.conf 文件中,配置项 database 16 设置了数据库的数量为16,默认数据库是0。

可以使用select 命令在连接上指定数据库id。

当我们没有默认选择库时,默认使用 0 库。

实例3:get key

127.0.0.1:6379> set a 1
OK
127.0.0.1:6379> get a
"1"
127.0.0.1:6379> set b {a:b,1:2}
OK
127.0.0.1:6379> get b
"{a:b,1:2}"
127.0.0.1:6379>

实例4:del key

127.0.0.1:6379> keys *
1) "system:role"
2) "b"
3) "set:test"
4) "set:test1"
5) "set:test2"
6) "system:group"
7) "system:user"
8) "a"
127.0.0.1:6379> del a # 删除成功
(integer) 1
127.0.0.1:6379> keys *
1) "system:role"
2) "b"
3) "set:test"
4) "set:test1"
5) "set:test2"
6) "system:group"
7) "system:user"
127.0.0.1:6379>
127.0.0.1:6379> del a #删除失败
(integer) 0

实例5:递增key

127.0.0.1:6379> incr test
(integer) 1
127.0.0.1:6379> get test
"1"
127.0.0.1:6379> incr test
(integer) 2
127.0.0.1:6379> get test
"2"
127.0.0.1:6379> incr test
(integer) 3
127.0.0.1:6379> get test
"3"
127.0.0.1:6379> incrby test 3
(integer) 6
127.0.0.1:6379> get test
"6"

当值(字符串)里是数字时,才可以自增。

实例6:递减key

127.0.0.1:6379> DECR test
(integer) 5

实例7:先取再设置(同时进行)

127.0.0.1:6379> getset test1 1
(nil)
127.0.0.1:6379> get test1
"1"
127.0.0.1:6379> getset test1 2
"1"
127.0.0.1:6379> get test1
"2"
127.0.0.1:6379>

redis getset 命令用于设定指定key的值,并返回key的旧值。

3、STRING 类型的实际场景

场景1:做商品详情和缓存

127.0.0.1:6379> set spu:10001 '{"color":"red","struct":"glass","length":30,"width":25,"price":"1345.20"}'
OK
127.0.0.1:6379> get spu:10001
"{\"color\":\"red\",\"struct\":\"glass\",\"length\":30,\"width\":25,\"price\":\"1345.20\"}"
127.0.0.1:6379>

说明:比如客户端发起请求查询 sup:10001 商品信息,api程序先去redis拿,拿到了就直接返回给api程序,api返回给客户端,这样就起到了做缓存的目的。

场景2:给数据做唯一编码

有一些数据需要唯一的编码去命名,如用例编码。

使用redis 用incr 生成用例编码

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

场景3:做分布式锁

1、什么是分布式锁:针对多服务的情况,在外面加个分布式锁,每个服务都要在获得分布式锁后进行操作。

2、Redis为什么可以做分布式锁:因为redis是单线程运行的,没有并发,所有请求都是一个一个操作。

3、redis怎么做分布式锁:

  expire [key] time     #设置一个key有效期

  exists [key]             # 判断key是否存在

  伪代码:

先判断锁是否存在(key存在,exists):

  如果存在:pass

  如果不存在:set key 'xxx' && 设置过期时间

        操作

4、如何设置过期时间&如何判断key是否存在

127.0.0.1:6379> set hqq2 'a'
OK
127.0.0.1:6379> exists hqq2 #判断key是否存在
(integer) 1
127.0.0.1:6379> expire hqq2 10 #设置过期时间为10s
(integer) 1 10秒后再次操作
127.0.0.1:6379> exists hqq2
(integer) 0
127.0.0.1:6379>

5、设置过期时间的实际应用场景:

set key '限时活动'
expire key 10
while get key:
继续活动
活动结束
127.0.0.1:6379> set 618day 'huodong'
OK
127.0.0.1:6379> expire 618day 100
(integer) 1
127.0.0.1:6379> get 618day
"huodong"
127.0.0.1:6379> get 618day
(nil)

4、总结STRING

1、一个key对应一个value

2、Redis的String可以包含任何数据,比如 jpg图片或者序列的对象

3、一个key最大能存储512MB

二、Redis 数据类型-HASH

1、什么是哈希值

哈希值是通常用一个短的随机字母和数字组成的字符串来代表,是一组任意长度的输入信息通过哈希算法得到的“数据指纹”。因为计算机在底层机器码是采用二进制的模式。因此通过哈希算法得到的任意长度的二进制值映射为较短的固定长度的二进制值,即哈希值。此外,哈希值是一段数据唯一且极其紧凑的数值表示形式,如果通过哈希一段明文得到哈希值,哪怕只更改该段明文中的任意一个字母,随后得到的哈希值都将不同。

 
2、Redis hash结构

  Redis hash 是一个键值对集合;

  Redis hash 是一个string类型的field 和 value 的映射表;

  hash 适合存储对象

3、设置

127.0.0.1:6379> hset htest1 key1 1
(integer) 1
127.0.0.1:6379> hget htest1 key1
"1"
127.0.0.1:6379> hset htest1 key2 2
(integer) 1
127.0.0.1:6379> hget htest1 key2
"2"

结构:

4、删除

127.0.0.1:6379[1]> hdel htest1 key1
(integer) 1
127.0.0.1:6379[1]> hget htest1 key1
(nil)

5、是否存在

127.0.0.1:6379[1]>  HEXISTS htest1 key1
(integer) 0 #不存在
127.0.0.1:6379[1]> HEXISTS htest1 key2
(integer) 1 #存在

6、展示key的所有的value(第二级的key)

127.0.0.1:6379[1]> hset htest1 key3 3
(integer) 1
127.0.0.1:6379[1]> hset htest1 key4 'a'
(integer) 1
127.0.0.1:6379[1]> hkeys htest1
1) "key2"
2) "key3"
3) "key4"

结构:

7、展示key 的所有的最后一级value

127.0.0.1:6379[1]> hvals htest1
1) "2"
2) "3"
3) "a"
127.0.0.1:6379[1]>

8、获取key下面的所有的键和值

127.0.0.1:6379[1]> hgetall htest1
1) "key2"
2) "2"
3) "key3"
4) "3"
5) "key4"
6) "a"

9、进阶实例

127.0.0.1:6379[1]> hmset w3ckey name 'redis tutorial' description 'redis basic commands for caching' likes 20 visitors 23000
OK
127.0.0.1:6379[1]> hgetall w3ckey
1) "name"
2) "redis tutorial"
3) "description"
4) "redis basic commands for caching"
5) "likes"
6) "20"
7) "visitors"
8) "23000"
127.0.0.1:6379[1]>

说明:

  设置了redis的一些描述信息(name,description,likes,visitors)到hash表的w3ckeys中。

10、redis hash 命令

序号
命令及描述
1
HDEL key field2 [field2] 删除一个或多个哈希表字段
2
HEXISTS key field 查看哈希表 key 中,指定的字段是否存在。
3
HGET key field 获取存储在哈希表中指定字段的值/td>
4
HGETALL key 获取在哈希表中指定 key 的所有字段和值
5
HINCRBY key field increment 为哈希表 key 中的指定字段的整数值加上增量 increment 。
6
HINCRBYFLOAT key field increment 为哈希表 key 中的指定字段的浮点数值加上增量 increment 。
7
HKEYS key 获取所有哈希表中的字段
8
HLEN key 获取哈希表中字段的数量
9
HMGET key field1 [field2] 获取所有给定字段的值
10
HMSET key field1 value1 [field2 value2 ] 同时将多个 field-value (域-值)对设置到哈希表 key 中。
11
HSET key field value 将哈希表 key 中的字段 field 的值设为 value 。
12
HSETNX key field value 只有在字段 field 不存在时,设置哈希表字段的值。
13
HVALS key 获取哈希表中所有值
14
HSCAN key cursor [MATCH pattern] [COUNT count] 迭代哈希表中的键值对。

三、Redis 数据类型-LIST

1、redis 列表是简单的字符串列表,按照插入顺序排序。

2、可以添加一个元素到列表的头部(左边)或者尾部(右边)。

3、redis list可以做什么:

  1)列表可以做什么:index-value  pop  append

  2)redis list同样可以 pop

4、常用基本命令

  • lpush [key] [element...]
  • rpush [key] [element...]
  • lpop [key]
  • rpop [key]
  • lrange [key] [start] [end]
  • llen [key]

5、实践

实践1:从左边插入

127.0.0.1:6379[1]> lpush ltest 1  #从左边插入
(integer) 1
127.0.0.1:6379[1]> lpush ltest 1
(integer) 2 #返回的是添加到第几个数
127.0.0.1:6379[1]> lpush ltest 2
(integer) 3
127.0.0.1:6379[1]> llen ltest #看长度
(integer) 3
127.0.0.1:6379[1]> lrange ltest 0 -1 #第一个0,最后一个-1
1) "2"
2) "1"
3) "1"

得到的结构类似:ltest:[2,1,1]

实践2:从右边插入

127.0.0.1:6379[1]> rpush ltest 3
(integer) 4
127.0.0.1:6379[1]> lrange ltest 0 -1
1) "2"
2) "1"
3) "1"
4) "3"

得到的结构类似:ltest:[2,1,1,3]

实践3:删除

127.0.0.1:6379[1]> lpop ltest      #从左边删除
"2"
127.0.0.1:6379[1]> lrange ltest 0 -1
1) "1"
2) "1"
3) "3"
127.0.0.1:6379[1]> rpop ltest #从右边删除
"3"
127.0.0.1:6379[1]> lrange ltest 0 -1
1) "1"
2) "1"

6、redis list 可以在实际工作中做什么?--消息队列

1)消息队列:ActiveMQ、RabbitMQ、ZeroMQ、Kafka、MetaMQ、RocketMQ等
2)什么是消息队列:
  我们可以把消息队列比作是一个存放消息的容器,当我们需要使用消息的时候可以取出消息供自己使用。  
  队列:先进先出
3)使用队列的好处:
好处1:通过异步处理提高系统性能。

在不使用消息队列服务器的时候,用户的请求数据直接写入数据库,在高并发的情况下数据库压力剧增,使得响应速度变慢。

使用消息队列之后,用户的请求数据发送给消息队列之后立即返回,再由消息队列的消费者进程从消息队列中获取数据,异步写入数据库。由于消息队列服务器处理速度快于数据库(消息队列也比数据库有更好的伸缩性),因此响应速度得到大幅改善。

 
好处2:降低系统耦合度

消息队列使利用发布-订阅模式工作,消息发送者(生产者)发布消息,一个或多个消息接受者(消费者)订阅消息,通过A的认证后就可以消费。
从上图可以看到消息发送者(生产者)和消息接受者(消费者)之间没有直接耦合,
消息发送者将消息发送至分布式消息队列即结束对消息的处理,
消息接受者从分布式消息队列获取该消息后进行后续处理,并不需要知道该消息从何而来。
对新增业务,只要对该类消息感兴趣,即可订阅该消息,对原有系统和业务没有任何影响,从而实现网站业务的可扩展性设计。
 
只有在解耦这个特定的场景下,使用发布-订阅模式。其他还有点对点订阅模式等。
 
坏处1:系统可用性降低
系统可用性在某种程度上降低,为什么这样说呢?在加入MQ之前,你不用考虑消息丢失或者说MQ挂掉等等的情况,但是,引入MQ之后你就需要去考虑了!
 
坏处2:系统复杂度提高
加入MQ之后,你需要保证消息没有被重复消费、处理消息丢失的情况、保证消息传递的顺序性等等问题!
 
坏处3:一致性问题
了消息队列可以实现异步,消息队列带来的异步确实可以提高系统响应速度。但是,万一消息的真正消费者并没有正确消费消息怎么办?这样就会导致数据不一致的情况了!
 
4)如何实现:lpush 先进;rpop 先出 就可以实现消息队列
 

四、Redis 数据类型-SET(集合)

1、Redis 的Set 是string类型的无序集合
集合成员是唯一的,这就意味着集合中不能出现重复的数据。
 
2、Redis 中 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
 
3、基本命令
• sadd [key] [member...]
• srem [key] [member]
• spop [key]
• scard [key]
• smembers [key]
 
4、实战
127.0.0.1:6379[1]> sadd stest redis
(integer) 1
127.0.0.1:6379[1]> sadd stest mongdb
(integer) 1
127.0.0.1:6379[1]> sadd stest mysql
(integer) 1
127.0.0.1:6379[1]> sadd stest mysql
(integer) 0
127.0.0.1:6379[1]> smembers stest
1) "mysql"
2) "mongdb"
3) "redis" 127.0.0.1:6379[1]> srem stest redis #删除某个元素
(integer) 1
127.0.0.1:6379[1]> smembers stest
1) "mysql"
2) "mongdb"
127.0.0.1:6379[1]> 127.0.0.1:6379[1]> scard stest #查看有几个元素
(integer) 2
127.0.0.1:6379[1]> sadd stest hqq
(integer) 1
127.0.0.1:6379[1]> scard stest
(integer) 3
127.0.0.1:6379[1]> smembers stest
1) "hqq"
2) "mysql"
3) "mongdb"
127.0.0.1:6379[1]> 随机删除:(因为是无序的)
127.0.0.1:6379[1]> spop stest
"mysql"
127.0.0.1:6379[1]> spop stest
"mongdb"

5、实际应用场景

1)可以使用Redis的Set数据类型跟踪一些唯一性数据

比如访问某一博客的唯一IP地址信息。
对于此场景,我们仅需在每次访问该博客时将访问者的IP存入Redis中,Set数据类型会自动保证IP地址的唯一性。
 
2)充分利用Set类型的服务端聚合操作方便、高效的特性,可以用于维护数据对象之间的关联关系。
比如所有购买某一电子设备的客户ID被存储在一个指定的Set中,而购买另外一种电子产品的客户ID被存储在另外一个Set中,如果此时我们想获取有哪些客户同时购买了这两种商品时,Set的intersections交集命令就可以充分发挥它的方便和效率的优势了。
 

五、Redis 数据类型-SORTEDSET

1、sorted set 有序集合
Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。
redis正是通过分数来为集合中的成员进行从小到大的排序。
有序集合的成员是唯一的,但分数(score)却可以重复。
 
2、集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 
 
3、常用命令
• zadd [key] [score] [member]
• zrem [key] [member]
• zcard [key]
• zrange [key] [start] [stop] [withscroes]
 

4、实战

127.0.0.1:6379[1]> zadd ztest 1 case1
(integer) 1
127.0.0.1:6379[1]> zadd ztest 2 case3
(integer) 1
127.0.0.1:6379[1]> zadd ztest 3 case2
(integer) 1
127.0.0.1:6379[1]> zrange ztest 0 -1
1) "case1"
2) "case3"
3) "case2"
127.0.0.1:6379[1]>

长度:
127.0.0.1:6379[1]> zcard ztest
(integer) 3 删除指定元素:
127.0.0.1:6379[1]> zrem ztest case1
(integer) 1
127.0.0.1:6379[1]> zrange ztest 0 -1
1) "case3"
2) "case2"
127.0.0.1:6379[1]> 返回索引:
127.0.0.1:6379[1]> zrank ztest case2
(integer) 1
127.0.0.1:6379[1]> zrank ztest case3
(integer) 0

5、实际应用场景

有序集合的使用场景与集合类似,但是set集合不是自动有序的,而sorted set可以利用分数进行成员间的排序,而且是插入时就排序好。所以当你需要一个有序且不重复的集合列表时,就可以选择sorted set数据结构作为选择方案。
 
1) 排行榜:有序集合经典使用场景。
 
可以用于一个大型在线游戏的积分排行榜。每当玩家的分数发生变化时,可以执行ZADD命令更新玩家的分数,此后再通过ZRANGE命令获取积分TOPTEN的用户信息。当然我们也可以利用ZRANK命令通过username来获取玩家的排行信息。最后我们将组合使用ZRANGE和ZRANK命令快速的获取和某个玩家积分相近的其他用户的信息。
 
2)用Sorted Sets来做带权重的队列,比如普通消息的score为2,重要消息的score为1,然后工作线程可以选择按score的来获取工作任务。让重要的任务优先执行。
 
3)Sorted-Set类型还可用于构建索引数据。
 

六、Redis 的数据库操作

• select [index]

• keys [partten]

• del [key]

• type [key]

• exists [key]           #判断是否存在key

• expire [key] time  #设置超时时间

• ttl a                      #查看key还剩多长时间

• flushdb                #删除指定db

• flushall                #删除所有db

Redis 学习笔记1:数据类型的更多相关文章

  1. Redis学习笔记1-Redis数据类型

    Redis数据类型 Redis支持5种数据类型,它们描述如下: Strings - 字符串 字符串是 Redis 最基本的数据类型.Redis 字符串是二进制安全的,也就是说,一个 Redis 字符串 ...

  2. Redis学习笔记(三)Redis支持的5种数据类型的总结

    继续Redis学习笔记(二)来说说剩余的三种数据类型. 三.列表类型(List) 1.介绍 列表类型可以存储一个有序的字符串列表,常用的操作是向列表两端添加元素,或者获得列表的一段片段.列表类型内部是 ...

  3. Redis学习笔记(二)Redis支持的5种数据类型的总结之String和Hash

    引言 在Redis学习笔记(一)中我们已经会安装并且简单使用Redis了,接下来我们一起来学习下Redis支持的5大数据类型. 简介 Redis是REmote DIctionary Server(远程 ...

  4. Redis学习笔记(二) Redis 数据类型

    Redis 支持五种数据类型:string(字符串).list(列表).hash(哈希).set(集合)和 zset(有序集合),接下来我们讲解分别讲解一下这五种类型的的使用. String(字符串) ...

  5. Redis学习笔记~目录

    回到占占推荐博客索引 百度百科 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合). ...

  6. Redis学习笔记4-Redis配置详解

    在Redis中直接启动redis-server服务时, 采用的是默认的配置文件.采用redis-server   xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务.按照本Redi ...

  7. Redis学习笔记(二)-key相关命令【转载】

    转自 Redis学习笔记(二)-key相关命令 - 点解 - 博客园http://www.cnblogs.com/leny/p/5638764.html Redis支持的各种数据类型包括string, ...

  8. Redis学习笔记(1)——Redis简介

    一.Redis是什么? Remote Dictionary Server(Redis) 是一个开源的使用ANSI C语言编写.遵守BSD协议.支持网络.可基于内存亦可持久化的日志型.Key-Value ...

  9. Redis学习笔记4-Redis配置具体解释

    在Redis中直接启动redis-server服务时, 採用的是默认的配置文件.採用redis-server   xxx.conf 这种方式能够依照指定的配置文件来执行Redis服务. 依照本Redi ...

  10. redis 学习笔记(6)-cluster集群搭建

    上次写redis的学习笔记还是2014年,一转眼已经快2年过去了,在段时间里,redis最大的变化之一就是cluster功能的正式发布,以前要搞redis集群,得借助一致性hash来自己搞shardi ...

随机推荐

  1. 【Windows】KMS 激活命令记录

    目录 KMS 服务器激活 Office.Visio 推荐使用 office tool plus 部署并配置 KMS 激活 什么是 KMS? KMS 正版与否的区别 总结 KMS 服务器激活 利用 KM ...

  2. [Python] #!/usr/bin/python 与 #!/usr/bin/env python 的区别

    区别是什么呢? #!/usr/bin/python 系统在执行这个脚本的时候, 调用固定路径的python解释器 #!/usr/bin/env python 防止用户没有吧py安装到usr/bin目录 ...

  3. 代码检视的新姿势!在IDEA中得到沉浸式Code Review新体验

    大家好,好久不见,又见面了. 在消失的这段时间里,我做了件大事,见证了儿子的出生并陪伴其一天天的成长.停止更文的200多天里,还能得到小伙伴们持续的支持,让我备受鼓励.对一个技术人员而言,分享技术观点 ...

  4. android模拟器推荐

    最近装了个海马模拟器用来调试cocos2dx-lua游戏. 安装完之后发现, 我之前装的virtual box被替换掉了, 因为海马模拟器要安装它自己匹配版本的virtual box, 所以我之前的装 ...

  5. Solution -「NOI 2021」轻重边

    Description Link. 给出一棵树,初始边权为 \(0\),支持毛毛虫虫体赋 \(1\),虫足赋 \(0\),以及查询路径边权和操作,\(n,m\leqslant 10^5\). Solu ...

  6. nginx ServerName匹配规则

    1.同一个主机配置不同端口,访问不同资源 worker_processes 1; events { worker_connections 1024; } http { include mime.typ ...

  7. 熟练掌握并充分利用CSS3的新特性,更新完毕。

    1.1  尝试新颖的CSS3特性 首先,我们来看一个具体的案例.  https://code.juejin.cn/pen/7277536985772720139   1.2  CSS3新特性简介和浏览 ...

  8. AIGC革新,将文字或者LOGO融入AI视频基于PIKA-labs(Python3.10)

    很多平台都会禁止用户使用带有网址或者二维码的头像以及文章配图,这样可以有效的防止用户的一些"导流"行为.当然,头像.文章或者视频现在都是AI来审,毕竟现在人工的成本实在太高,但是如 ...

  9. Python并发编程——协程、Greenlet模块、Gevent模块、Gevent之同步与异步、Gevent应用

    文章目录 一 引子 二 协程介绍 三 Greenlet 四 Gevent介绍 五 Gevent之同步与异步 六 Gevent之应用举例一 七 Gevent之应用举例二 一 引子 本节的主题是基于单线程 ...

  10. 高效数据传输:Java通过绑定快速将数据导出至Excel

    摘要:本文由葡萄城技术团队于博客园原创并首发.转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 前言 把数据导出至 Excel 是很常见的需求,而数据的持久化 ...