Redis五大数据类型之String

Posted 王六六的IT日常

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis五大数据类型之String相关的知识,希望对你有一定的参考价值。

五大数据类型

1.String (字符串)
2.List(列表)
3.Set(集合)
4.Hash(哈希)
5.Zset(有序集合)

Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件MQ。
Redis支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与范围查询, bitmaps, hyperloglogs 和 地理空间(geospatial) 索引半径查询。
Redis 内置了复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的磁盘持久化(persistence), 并通过Redis哨兵(Sentinel)和自动分区(Cluster)提供高可用性(high availability)。

Redis-Key

以下的命令一定要全部记住,后面使用SpringBoot。
Jedis,所有的方法就是这些命令!
单点登录

127.0.0.1:6379> keys *  # 查看所有的key
(empty array)
127.0.0.1:6379> set name wangliuliu  # set key
OK
127.0.0.1:6379> keys *
1) "name"
127.0.0.1:6379> set age 19
OK
127.0.0.1:6379> keys *
1) "age"
2) "name"
127.0.0.1:6379> EXISTS name # 判断当前的key是否存在
(integer) 1
127.0.0.1:6379> EXISTS name1
(integer) 0
127.0.0.1:6379> move name 1  # 移除当前的key
(integer) 1
127.0.0.1:6379> keys *
1) "age"
127.0.0.1:6379> set name wanzi
OK
127.0.0.1:6379> keys *
1) "age"
2) "name"
127.0.0.1:6379> get name
"wanzi"
127.0.0.1:6379> EXPIRE name 10  # 设置key的过期时间,单位是秒
(integer) 1
127.0.0.1:6379> ttl name # 查看当前key的剩余时间
(integer) 2
127.0.0.1:6379> ttl name  #显示-2为过时
(nil)
127.0.0.1:6379> type name # 查看当前key的一个类型
none
127.0.0.1:6379> type age # 查看当前key的一个类型
string

后面如果遇到不会的命令,可以在官网查看帮助文档

1.String (字符串)

90% 的 java程序员使用 redis 只会使用一个String类型!
1.进入Redis终端:

基础的一些命令:
[root@wanzi ~]# docker exec -it 7b1a04e7447d redis-cli  #进入终端
127.0.0.1:6379> keys * # 获得所有的key
(empty array)
127.0.0.1:6379> set key1 value1  # 设置值
OK
127.0.0.1:6379> get key1  # 获得值
"value1"
127.0.0.1:6379> keys * # 查看所有的key
1) "key1"
127.0.0.1:6379> exists key1  # 判断某一个key是否存在
(integer) 1
127.0.0.1:6379> append key1 "hello" # 追加字符串,如果当前key不存在,就相当于setkey
(integer) 11
127.0.0.1:6379> get key1
"value1hello"
127.0.0.1:6379> strlen key1 # 获取字符串的长度
(integer) 11
127.0.0.1:6379> append key1 ",wangliuliu"
(integer) 22
127.0.0.1:6379> strlen key1
(integer) 22
127.0.0.1:6379> get key1
"value1hello,wangliuliu"
127.0.0.1:6379> append name "wanzi" # 如果当前key不存在,就相当于setkey
(integer) 5
127.0.0.1:6379> keys *
1) "key1"
2) "name"

Java里自增:i++ ;步长 i+=
127.0.0.1:6379> set views 0 # 初始浏览量为0
OK
127.0.0.1:6379> get views
"0"
127.0.0.1:6379> incr views  # 自增1 浏览量变为1
(integer) 1
127.0.0.1:6379> incr views
(integer) 2
127.0.0.1:6379> get views
"2"
127.0.0.1:6379> decr views # 自减1  
(integer) 1
127.0.0.1:6379> decr views
(integer) 0
127.0.0.1:6379> decr views # 自减1  浏览量-1
(integer) -1
127.0.0.1:6379> incrby views 10 # 可以设置步长,指定增量
(integer) 9
127.0.0.1:6379> incrby views 10
(integer) 19
127.0.0.1:6379> decrby views 5
(integer) 14
Java里获取字符串范围:字符串范围 range

127.0.0.1:6379> set key1 "hello,wanzi" # 设置 key1 的值
OK
127.0.0.1:6379> get key1
"hello,wanzi"
127.0.0.1:6379> getrange key1 0 3 # 截取字符串 [0,3]
"hell"
127.0.0.1:6379> getrange key1 0 -1 # 获取全部的字符串 和 get key是一样的
"hello,wanzi"

java中替换:

127.0.0.1:6379> set key2 abcdefg
OK
127.0.0.1:6379> get key2
"abcdefg"
127.0.0.1:6379> setrange key2 1 xx # 替换指定位置开始的字符串
(integer) 7
127.0.0.1:6379> get key2
"axxdefg"
当前这个值是否存在:
  • setex (set with expire) # 如果当前key存在 设置过期时间
127.0.0.1:6379> setex key3 30 "hello" #设置key3 的值为 hello,30秒后过期
OK
127.0.0.1:6379> ttl key3 #查看剩余时间
(integer) 26
127.0.0.1:6379> ttl key3
(integer) 23
127.0.0.1:6379> get key3 # 获得值,还存在
"hello"
127.0.0.1:6379> ttl key3 #过期了
(integer) -2
127.0.0.1:6379> get key3 #获得值,不存在
(nil)
  • setnx (set if not exist) # 如果当前key不存在,再设置 (在分布式锁中会常常使用!):设置成功返回1,不成功返回0
127.0.0.1:6379> setnx mykey "redis" # 如果mykey 不存在,创建mykey
(integer) 1
127.0.0.1:6379> keys *
1) "mykey"
2) "key2"
3) "key1"
127.0.0.1:6379> setnx mykey "MongoDB" # 如果mykey存在,创建失败
(integer) 0 #失败
一次性设置多个值:
  • mset:同时设置多个值
  • mget:同时获取多个值
  • msetnx:一个原子性的操作,要么一起成功,要么一起失败
127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3 # 同时设置多个值
OK
127.0.0.1:6379> keys * # 获得所有的key
1) "k3"
2) "k2"
3) "k1"
127.0.0.1:6379> mget k1 k2 k3 # 同时获取多个值
1) "v1"
2) "v2"
3) "v3"
127.0.0.1:6379> msetnx k1 v1 k4 v4 # msetnx 是一个原子性的操作,要么一起成功,要么一起
失败
(integer) 0
127.0.0.1:6379> get k4
(nil)
设置对象:

set user:1 name:wanzi,age:19👉设置一个user:1 对象 值为 json字符来保存一个对象! user:id:filed

# 这里的key是一个巧妙的设计: user:id:filed , 如此设计在Redis中是完全OK了!
127.0.0.1:6379> mset user:1:name wanzi  user:1:age 19
OK
127.0.0.1:6379> mget user:1:name user:1:age
1) "wanzi"
2) "19"

例如:127.0.0.1:6379> set article:10000:views 0 将第10000篇文章的浏览量设置为0

getset :先get然后在set(更新)
  • 如果不存在值,则返回 nil
  • 如果存在值,获取原来的值,并设置新的值
127.0.0.1:6379> getset db redis # 如果不存在值,则返回 nil
(nil)
127.0.0.1:6379> get db
"redis"
127.0.0.1:6379> getset db MongoDB # 如果存在值,获取原来的值,并设置新的值
"redis"
127.0.0.1:6379> get db
"MongoDB"

数据结构是相同的。
String类似的使用场景:value除了是字符串还可以是数字
例如:

  • 计数器
  • 统计多单位的数量
  • 粉丝数
  • 对象缓存存储!

以上是关于Redis五大数据类型之String的主要内容,如果未能解决你的问题,请参考以下文章

Redis五大数据类型之Set

Redis五大数据类型之String

Redis五大数据类型之List

redis之五大数据类型介绍

Redis五大常见的数据类型之 Hash

NoSQL之 Redis的五大数据类型的详细介绍