目录
Redis是一个key-value的数据库,key一般是String类型,不过value的类型多种多样:
value的数据类型共有8种,前面5中为基本数据类型,后面3种是针对不同的情况指定的特殊数据类型。
命令不要死记,学会查询就好啦
Redis为了方便我们学习,将操作不同数据类型的命令也做了分组,在官网( Commands | Redis)可以查看到不同的命令:(点击COMMANDS)
当然我们也可以通过Help命令来帮助我们去查看命令
通用指令是部分数据类型的,都可以使用的指令,常见的有:
KEYS:查看符合模板的所有key
DEL:删除一个指定的key
EXISTS:判断key是否存在
EXPIRE:给一个key设置有效期,有效期到期时该key会被自动删除
TTL:查看一个KEY的剩余有效期
通过help [command] 可以查看一个命令的具体用法,例如:
接下来演示上述常用命令的使用:
温馨提示:以下的内容所有的代码块都是从命令行窗口复制过来的,包括命令和结果哦~
1.KEYS:查看符合模板的所有key
- 127.0.0.1:6379> keys *
- 1) "name"
- 2) "age"
- 127.0.0.1:6379>
-
- # 查询以a开头的key
- 127.0.0.1:6379> keys a*
- 1) "age"
- 127.0.0.1:6379>
贴心小提示:在生产环境下,不推荐使用keys 命令,因为这个命令在key过多的情况下,效率不高
2.DEL:删除一个指定的key
- 127.0.0.1:6379> help del
-
- DEL key [key ...]
- summary: Delete a key
- since: 1.0.0
- group: generic
-
- 127.0.0.1:6379> del name #删除单个
- (integer) 1 #成功删除1个
-
- 127.0.0.1:6379> keys *
- 1) "age"
-
- 127.0.0.1:6379> MSET k1 v1 k2 v2 k3 v3 #批量添加数据
- OK
-
- 127.0.0.1:6379> keys *
- 1) "k3"
- 2) "k2"
- 3) "k1"
- 4) "age"
-
- 127.0.0.1:6379> del k1 k2 k3 k4
- (integer) 3 #此处返回的是成功删除的key,由于redis中只有k1,k2,k3 所以只成功删除3个,最终返回
- 127.0.0.1:6379>
-
- 127.0.0.1:6379> keys * #再查询全部的key
- 1) "age" #只剩下一个了
- 127.0.0.1:6379>
贴心小提示:在拷贝代码的时候,只需要拷贝对应的命令哦~
3.EXISTS:判断key是否存在
- 127.0.0.1:6379> help EXISTS
-
- EXISTS key [key ...]
- summary: Determine if a key exists
- since: 1.0.0
- group: generic
-
- 127.0.0.1:6379> exists age
- (integer) 1
-
- 127.0.0.1:6379> exists name
- (integer) 0
4.EXPIRE:给一个key设置有效期,有效期到期时该key会被自动删除
5.TTL:查看一个KEY的剩余的存活时间
- 127.0.0.1:6379> expire age 10
- (integer) 1
-
- 127.0.0.1:6379> ttl age
- (integer) 8
-
- 127.0.0.1:6379> ttl age
- (integer) 6
-
- 127.0.0.1:6379> ttl age
- (integer) -2
-
- 127.0.0.1:6379> ttl age
- (integer) -2 #当这个key过期了,那么此时查询出来就是-2
-
- 127.0.0.1:6379> keys *
- (empty list or set)
-
- 127.0.0.1:6379> set age 10 #如果没有设置过期时间
- OK
-
- 127.0.0.1:6379> ttl age
- (integer) -1 # ttl的返回值就是-1
贴心小提示:
(1)内存非常宝贵,对于一些数据,我们应当给他一些过期时间,当过期时间到了之后,他就会自动被删除~
(2)当使用TTL命令时,如果返回 -1 值,不是代表已经被销毁,而是代表永久哦~
Redis没有类似MySQL中的Table的概念,我们该如何区分不同类型的key呢?
例如,需要存储用户.商品信息到redis,有一个用户id是1,有一个商品id恰好也是1,此时如果使用id作为key,那就会冲突了,该怎么办?
我们可以通过给key添加前缀加以区分,不过这个前缀不是随便加的,有一定的规范:
Redis的key允许有多个单词形成层级结构,多个单词之间用':'隔开,格式如下:
这个格式并非固定,也可以根据自己的需求来删除或添加词条。
这个格式并非固定,也可以根据自己的需求来删除或添加词条。
例如我们的项目名称叫 heima,有user和product两种不同类型的数据,我们可以这样定义key:
user相关的key:heima:user:1
product相关的key:heima:product:1
如果Value是一个Java对象,例如一个User对象,则可以将对象序列化为JSON字符串后存储:
KEY | VALUE |
---|---|
heima:user:1 | {"id":1, "name": "Jack", "age": 21} |
heima:product:1 | {"id":1, "name": "小米11", "price": 4999} |
一旦我们向redis采用这样的方式存储,那么在可视化界面中,redis会以层级结构来进行存储,形成类似于这样的结构,更加方便Redis获取数据