当前位置:   article > 正文

【Redis】五大数据结构及其常用指令_redis 的各个结构以及操作命令

redis 的各个结构以及操作命令

说明

Redis里面的数据类型有String、List、Set、Hash、Zset。这篇文章会介绍这5种数据类型并介绍操作它们的指令.

String类型

字符串是一种最基本的Redis值类型。Redis字符串是二进制安全的,这意味着一个Redis字符串能包含任意类型的数据,例如: 一张JPEG格式的图片或者一个序列化的Ruby对象。

一个字符串类型的值最多能存储512M字节的内容。

下面是字符串的一些指令

添加值 set <key> <value>

127.0.0.1:6379> set name ttpfx
OK
  • 1
  • 2

获取值 get <key>

127.0.0.1:6379> get name
"ttpfx"
  • 1
  • 2

将给定的 <value> 追加到原值的末尾 append <key> <value>

127.0.0.1:6379> append name 123
(integer) 8
127.0.0.1:6379> get name
"ttpfx123"
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5

strlen获取对应key的长度 strlen <key>

127.0.0.1:6379> get name
"ttpfx123"
127.0.0.1:6379> strlen name
(integer) 8
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5

setnx只有在对应key不存在的时候才设置key的值 setnx <key> <value>

127.0.0.1:6379> keys *
1) "name"
127.0.0.1:6379> setnx name hello
(integer) 0
127.0.0.1:6379> setnx age 20
(integer) 1
127.0.0.1:6379> keys *
1) "name"
2) "age"
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

incr 将key中存储的值+1,只能操作数字,如果不存在key,那么就设置key,值为1 。incr <key>

127.0.0.1:6379> get age
"20"
127.0.0.1:6379> incr age
(integer) 21
127.0.0.1:6379> incr name
(error) ERR value is not an integer or out of range
127.0.0.1:6379>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

还有一个decr,效果和incr基本一样的,只不过是将值-1,如果不存在值,那么初始值为-1 decr <key>

127.0.0.1:6379> get age
"21"
127.0.0.1:6379> decr age
(integer) 20
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5

增加/减少指定值,incrby / decr <key> <value>,如果对应的key不存在,那么创建对应key并设置为 ±指定的值

127.0.0.1:6379> incrby age 5
(integer) 25
127.0.0.1:6379> decrby age 5
(integer) 20
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5

一次设置多个k-v,那么就使用mset ,指令格式为 mset <key1> <value> <key2> <value2> …

127.0.0.1:6379> mset a1 1 a2 2 a3 3
OK
127.0.0.1:6379> 
  • 1
  • 2
  • 3

一次获取多个key的值,使用mget,指令格式为 mget <key1> <key2> …

127.0.0.1:6379> mget a1 a2 a3
1) "1"
2) "2"
3) "3"
127.0.0.1:6379> mget a1 a4
1) "1"
2) (nil)
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

一次设置多个k-v,当对应的k不存在才设置,使用 msetnx <key1> <value> <key2> <value2> …,需要注意的是,这个操作要所有的key都不存在才进行设置value,是原子性的,存在任意一个key都会执行失败。

127.0.0.1:6379> msetnx d1 1 d2 2 d3 3
(integer) 1
127.0.0.1:6379> msetnx e1 1 e2 2 d3 3
(integer) 0
127.0.0.1:6379> get e1
(nil)
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

获取对应key字串,使用getrange,语法为 getrange <key> <start> <end>,两边都是闭区间

127.0.0.1:6379> getrange name 0 3
"ttpf"
127.0.0.1:6379> getrange name 0 100
"ttpfx123"
127.0.0.1:6379> getrange name 100 1000
""
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

更改对应key的部分内容,使用setrange,语法为 **setrange <key> <start> **,会从start位置开始进行覆盖

127.0.0.1:6379> get name
"ttpfx123"
127.0.0.1:6379> setrange name 5 4567
(integer) 9
127.0.0.1:6379> get name
"ttpfx4567"
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

可以给key设置过期时间,指令为 setex <key> <过期时间(秒)> <value> ,查看过期时间使用ttl key

127.0.0.1:6379> setex money 10 888
OK
127.0.0.1:6379> get money
"888"
127.0.0.1:6379> ttl money
(integer) 5
127.0.0.1:6379> ttl money
(integer) 3
127.0.0.1:6379> ttl money
(integer) -2
127.0.0.1:6379> get money
(nil)
127.0.0.1:6379>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

通过getset指令可以实现以旧换新,再设置新值的时候返回旧值 getset <key> <value>

127.0.0.1:6379> get name
"ttpfx123"
127.0.0.1:6379> getset name ttpfx
"ttpfx123"
127.0.0.1:6379> get name
"ttpfx"
127.0.0.1:6379> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

***

List类型

Redis列表是简单的字符串列表,按照插入顺序排序。List是一个双向链表

image-20230404134440545

**lpush/rpush <key> <value1> <value2> … **从左边/右边插入一个或多个值

127.0.0.1:6379[1]> lpush names tom jack
(integer) 2
127.0.0.1:6379[1]> lrange names 0 -1
1) "jack"
2) "tom"
127.0.0.1:6379[1]> rpush names t1 t2
(integer) 4
127.0.0.1:6379[1]> lrange names 0 -1
1) "jack"
2) "tom"
3) "t1"
4) "t2"
127.0.0.1:6379[1]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

**lpop/rpop <key> [count] ** 左边/右边删除count个值,count是可选值,不写默认就是1

127.0.0.1:6379[1]> lrange names 0 -1
1) "jack"
2) "tom"
3) "t1"
4) "t2"
127.0.0.1:6379[1]> lpop names
"jack"
127.0.0.1:6379[1]> lpop names 2
1) "tom"
2) "t1"
127.0.0.1:6379[1]> lrange names 0 -1
1) "t2"
127.0.0.1:6379[1]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

rpoplpush <source> <destination> 相当于对source执行rpop,对destination执行lpush

127.0.0.1:6379[1]> lrange k1s 0 -1
1) "c"
2) "b"
3) "a
127.0.0.1:6379[1]> lrange k2s 0 -1
1) "e"
2) "d"
3) "c"
127.0.0.1:6379[1]> rpoplpush k1s k2s
"a"
127.0.0.1:6379[1]> lrange k1s 0 -1
1) "c"
2) "b"
127.0.0.1:6379[1]> lrange k2s 0 -1
1) "a"
2) "e"
3) "d"
4) "c"
127.0.0.1:6379[1]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

lrange <key> <start> <end> 返回列表指定索引区间的元素,最左边开始为0,最右边开始为-1,都是闭区间

127.0.0.1:6379[1]> lrange names 0 -1
1) "t1"
2) "t2"
3) "t3"
4) "t4"
127.0.0.1:6379[1]> lrange names 0 2
1) "t1"
2) "t2"
3) "t3"
127.0.0.1:6379[1]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

lindex <key> <i> 获得指定索引的元素

127.0.0.1:6379[1]> lindex names 1
"t2"
127.0.0.1:6379[1]> lindex names -1
"t4"
127.0.0.1:6379[1]>
  • 1
  • 2
  • 3
  • 4
  • 5

llen <key> 获取指定列表的长度

127.0.0.1:6379[1]> llen names
(integer) 4
127.0.0.1:6379[1]> 
  • 1
  • 2
  • 3

**linsert <key> [before|after] <value> <newValue> ** 在指定集合的第一个value前面/后面插入一个newValue

127.0.0.1:6379[1]> lrange names 0 -1
1) "t1"
2) "t2"
3) "t3"
4) "t4"
127.0.0.1:6379[1]> linsert names before t2 a
(integer) 5
127.0.0.1:6379[1]> linsert names after t2 a
(integer) 6
127.0.0.1:6379[1]> lrange names 0 -1
1) "t1"
2) "a"
3) "t2"
4) "a"
5) "t3"
6) "t4"
127.0.0.1:6379[1]> linsert names after a b
(integer) 7
127.0.0.1:6379[1]> lrange names 0 -1
1) "t1"
2) "a"
3) "b"
4) "t2"
5) "a"
6) "t3"
7) "t4"
127.0.0.1:6379[1]>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

**lrem <key> <count> <value> ** 从左边开始删除count个value,会返回删除的个数

127.0.0.1:6379[1]> lrange names 0 -1
1) "t1"
2) "a"
3) "b"
4) "t2"
5) "a"
6) "t3"
7) "t4"
127.0.0.1:6379[1]> lrem names 2 a
(integer) 2
127.0.0.1:6379[1]> lrange names 0 -1
1) "t1"
2) "b"
3) "t2"
4) "t3"
5) "t4"
127.0.0.1:6379[1]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

lset <key> <index> <value> 设置指定下标的值

127.0.0.1:6379[1]> lrange names 0 -1
1) "t1"
2) "t2"
3) "t3"
4) "t4"
127.0.0.1:6379[1]> lset names 1 tom
OK
127.0.0.1:6379[1]> lset names 100 jack
(error) ERR index out of range
127.0.0.1:6379[1]> lrange names 0 -1
1) "t1"
2) "tom"
3) "t3"
4) "t4"
127.0.0.1:6379[1]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15


Set类型

Set和List都是集合,不同之处就是Set不允许有重复元素。

sadd key element [element …] 添加元素

127.0.0.1:6379[2]> sadd names tom jack
(integer) 2
127.0.0.1:6379[2]> smembers names
1) "tom"
2) "jack"
127.0.0.1:6379[2]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

smembers key 查看set中所有元素

127.0.0.1:6379[2]> smembers names
1) "tom"
2) "jack"
127.0.0.1:6379[2]> 
  • 1
  • 2
  • 3
  • 4

**sismember key value ** 判断某个set中是否有某个值,有返回1,没有返回0

127.0.0.1:6379[2]> smembers names
1) "tom"
2) "jack"
127.0.0.1:6379[2]> sismember names tom
(integer) 1
127.0.0.1:6379[2]> sismember names lucy
(integer) 0
127.0.0.1:6379[2]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

scard key 返回set元素个数

127.0.0.1:6379[2]> scard names
(integer) 2
127.0.0.1:6379[2]> 
  • 1
  • 2
  • 3

srem key value [value …] 删除一个或多个值

127.0.0.1:6379[2]> smembers names
1) "tom"
2) "jack"
3) "jery"
4) "ttpfx"
127.0.0.1:6379[2]> srem names tom jack
(integer) 2
127.0.0.1:6379[2]> smembers names
1) "jery"
2) "ttpfx"
127.0.0.1:6379[2]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

spop key [count] 随机删除count个值,不写count默认就是1

127.0.0.1:6379[2]> smembers names
1) "tom"
2) "jack"
3) "jery"
4) "ttpfx"
127.0.0.1:6379[2]> spop names 
"jack"
127.0.0.1:6379[2]> spop names 2
1) "tom"
2) "jery"
127.0.0.1:6379[2]> smembers names
1) "ttpfx"
127.0.0.1:6379[2]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

**srandmember key [count] ** 和spop基本用于,只不过不会删除对应元素

127.0.0.1:6379[2]> smembers names
1) "tom"
2) "jack"
3) "jery"
4) "ttpfx"
127.0.0.1:6379[2]> srandmember names 
"jack"
127.0.0.1:6379[2]> srandmember names 2
1) "tom"
2) "jery"
127.0.0.1:6379[2]> smembers names
1) "tom"
2) "jack"
3) "jery"
4) "ttpfx"
127.0.0.1:6379[2]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

smove source destination value 将指定值从一个Set移到另外一个Set

127.0.0.1:6379[2]> smembers t1
1) "a"
2) "b"
127.0.0.1:6379[2]> smembers t2
1) "c"
2) "d"
127.0.0.1:6379[2]> smove t1 t2 a
(integer) 1
127.0.0.1:6379[2]> smembers t1
1) "b"
127.0.0.1:6379[2]> smove t1 t2 a
(integer) 0
127.0.0.1:6379[2]> smembers t2
1) "a"
2) "c"
3) "d"
127.0.0.1:6379[2]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

sinter/sunion/sdiff key [key …] 对指定集合进行交集/并集/差集运算

127.0.0.1:6379[2]> smembers x1
1) "c"
2) "a"
3) "b"
127.0.0.1:6379[2]> smembers x2
1) "c"
2) "d"
3) "b"
127.0.0.1:6379[2]> sinter x1 x2
1) "c"
2) "b"
127.0.0.1:6379[2]> sunion x1 x2
1) "a"
2) "c"
3) "d"
4) "b"
127.0.0.1:6379[2]> sdiff x1 x2
1) "a"
127.0.0.1:6379[2]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19


Hash类型

hash是一个键值对的集合,类似于java中的HashMap,一般用于存储对象

hset key filed value [filed value] 给key对象中的filed字段设置值,hmset作用是一样的,但是根据Redis 4.0.0,HMSET被视为已弃用。请在新代码中使用HSET。

127.0.0.1:6379[3]> hset user name ttpfx age 20
(integer) 2
127.0.0.1:6379[3]> 
  • 1
  • 2
  • 3

hmget key filed [filed] 获取key里面对应字段的值,hget key filed 获取key中filed的值

127.0.0.1:6379[3]> hmget user name age salary
1) "ttpfx"
2) "20"
3) (nil)
127.0.0.1:6379[3]> hget user name
"ttpfx"
127.0.0.1:6379[3]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

hexists key filed 对应的key中是否存在filed字段

127.0.0.1:6379[3]> hexists user name
(integer) 1
127.0.0.1:6379[3]> hexists user salary
(integer) 0
127.0.0.1:6379[3]> 
  • 1
  • 2
  • 3
  • 4
  • 5

hkeys key 列出对应key中所有的字段

127.0.0.1:6379[3]> hkeys user
1) "name"
2) "age"
127.0.0.1:6379[3]> 
  • 1
  • 2
  • 3
  • 4

hvals key 列出对应key中的所有值

127.0.0.1:6379[3]> hvals user
1) "ttpfx"
2) "20"
127.0.0.1:6379[3]> 
  • 1
  • 2
  • 3
  • 4

hincrby key filed increment 给key中的指定字段值加上某个数

127.0.0.1:6379[3]> hincrby user age -1
(integer) 19
127.0.0.1:6379[3]> hincrby user age 10
(integer) 29
127.0.0.1:6379[3]> 
  • 1
  • 2
  • 3
  • 4
  • 5

hsetnx key filed value 当key中不存在filed字段时才进行设置该值

127.0.0.1:6379[3]> hsetnx user name tom
(integer) 0
127.0.0.1:6379[3]> hsetnx user salary 88888
(integer) 1
127.0.0.1:6379[3]> 
  • 1
  • 2
  • 3
  • 4
  • 5


Sorted Set 排序集合

和Set类似,只不过多了一个score来代表权重,集合中的元素根据score进行排序

zadd key [NX|XX] [CH] [INCR] score member [score member …],添加字段,score是一个double值

可选参数解释如下:

  • XX: 仅仅更新存在的成员,不添加新成员。
  • NX: 不更新存在的成员。只添加新成员。
  • CH: 修改返回值为发生变化的成员总数,原始是返回新添加成员的总数 (CH 是 changed 的意思)。更改的元素是新添加的成员,已经存在的成员更新分数。 所以在命令中指定的成员有相同的分数将不被计算在内。注:在通常情况下,ZADD返回值只计算新添加成员的数量。
  • INCR: 当ZADD指定这个选项时,成员的操作就等同ZINCRBY命令,对成员的分数进行递增操作。
127.0.0.1:6379[4]> zadd sgyy 100 gy 200 zf 300 zy 400 mc 500 hz
(integer) 5
127.0.0.1:6379[4]> 
  • 1
  • 2
  • 3

zrange key min max [withscorces] 返回下标在[min,max]之间的值,使用withscorces可以返回对应的分数

127.0.0.1:6379[4]> zrange sgyy 0 2
1) "gy"
2) "zf"
3) "zy"
127.0.0.1:6379[4]> zrange sgyy 0 2 withscores
1) "gy"
2) "100"
3) "zf"
4) "200"
5) "zy"
6) "300"
127.0.0.1:6379[4]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

zscore key member 返回member对应的score

127.0.0.1:6379[4]> zscore sgyy zy
"300"
127.0.0.1:6379[4]> 
  • 1
  • 2
  • 3

zrangebyscore key min max [withscores] [limit offset count] 返回指定score区间的值,都是闭区间

zrevrangebyscore 和zrangebyscore 基本一样的,就是按照max,min来指定区间

127.0.0.1:6379[4]> zrangebyscore sgyy 100 350 withscores
1) "gy"
2) "100"
3) "zf"
4) "200"
5) "zy"
6) "300"
127.0.0.1:6379[4]> zrangebyscore sgyy 100 350 withscores limit 0 2
1) "gy"
2) "100"
3) "zf"
4) "200"
127.0.0.1:6379[4]> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

zincrby key increment member 增加某个元素的score

127.0.0.1:6379[4]> zincrby sgyy -50 gy
"50"
127.0.0.1:6379[4]> 
  • 1
  • 2
  • 3

zrem key member [member] 删除对应的值

127.0.0.1:6379[4]> zrem sgyy hz mc
(integer) 2
127.0.0.1:6379[4]> 
  • 1
  • 2
  • 3

zcount key min max 统计分数区间内有多少个元素

127.0.0.1:6379[4]> zcount sgyy 50 200
(integer) 2
127.0.0.1:6379[4]> 
  • 1
  • 2
  • 3

zrank key member 返回指定元素在集合中的排名,0开始

127.0.0.1:6379[4]> zrank sgyy gy
(integer) 0
127.0.0.1:6379[4]> zrank sgyy zf
(integer) 1
127.0.0.1:6379[4]> 
  • 1
  • 2
  • 3
  • 4
  • 5

***

总结

上面只是部分常用的指令,关于操作数据的指令还有很多,可以参考 redis命令中心

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/513048
推荐阅读
相关标签
  

闽ICP备14008679号