1.String
set
127.0.0.1:6379> help set
SET key value [EX seconds] [PX milliseconds] [NX|XX]
在 Redis 中设置值,默认,不存在则创建,存在则修改
参数:
ex,过期时间(秒)
px,过期时间(毫秒)
nx,假如设置为True,则只有 name 不存在时,当前 set 操作才执行
xx,假如设置为True,则只有 name 存在时,当前 set 操作才执行
Example
127.0.0.1:6379> set name shark EX 10
OK
127.0.0.1:6379> get name
"shark"
setnx
127.0.0.1:6379> help setnx
SETNX key value
设置值,只有name 不存在时,执行设置操作(添加)
Example
127.0.0.1:6379> setnx age 10
(integer) 1
127.0.0.1:6379> get age
"10"
127.0.0.1:6379> setnx age 20
(integer) 0
127.0.0.1:6379> get age
"10"
127.0.0.1:6379>
setex
127.0.0.1:6379> help setex
SETEX key seconds value
设置 key 和 value,并且指的过期时间(单位: 秒)
Example
127.0.0.1:6379> setex name 5 shark
OK
get
获取一个 key 的 value
127.0.0.1:6379> get name
"shark"
ttl
查看一个 key 的过期时间
127.0.0.1:6379> ttl age
(integer) -1
-1 永不过期
-2 已经过期
expire
设置一个 key 的过期时间(单位: 秒)
127.0.0.1:6379> EXPIRE age 10
(integer) 1
127.0.0.1:6379> ttl age
(integer) 7
persist key
移除 key 的过期时间
mset
一次添加多个值
127.0.0.1:6379> mset name shark age 10
OK
mget
一次获取多个 key 的值
127.0.0.1:6379> MGET name age
1) "shark"
2) "10
incr
对一个 key 的值自增 1
127.0.0.1:6379> incr age
(integer) 11
decr
对一个 key 的值自减 1
127.0.0.1:6379> DECR age
(integer) 10
append
向一个 key 的值后面追加内容
127.0.0.1:6379> get n
"10"
127.0.0.1:6379> APPEND n 10
(integer) 4
127.0.0.1:6379> get n
"1010"
getrange
127.0.0.1:6379> GETRANGE n 0 -1
"1010"
**del**
删除 一个或者多个 key
127.0.0.1:6379> del name age
(integer) 2
EXISTS
判断一个 key 是否存在, 返回 1 表示存在, 0 表示不存在
127.0.0.1:6379> exists age
(integer) 1
127.0.0.1:6379> exists aaa
(integer) 0
127.0.0.1:6379>
TYPE
返回key存储的类型,如果不存在则返回none
type key
keys
通过通配符来获取匹配到的 key
一般不在生产环境中使用此命令
- 匹配所有
? 匹配任意一个
127.0.0.1:6379> keys *
1) "num"
2) "age"
3) "n"
127.0.0.1:6379> keys n*
1) "num"
2) "n"
127.0.0.1:6379> keys a[f-g]
(empty list or set)
127.0.0.1:6379> keys a[e-g]?
1) "age"
scan
dbsize
返回数据库种 key 的总数
dbsize
EXPIRE
设置key的过期时间,如果key不存在则返回0,否则返回1.如果key已经存在过期时间则再设置会覆盖之前的过期时间
2.List
lpush
向列表左端添加元素,values是按左到右依次插入的,返回值为列表中元素个数,列表元素可以重复
最后加入到元素,在列表的第一位
127.0.0.1:6379> LPUSH list a b c
(integer) 3
127.0.0.1:6379> LPUSH list a b c
(integer) 6
rpush
向列表右端依次的添加元素,最后加入的元素在列表的最后位置
127.0.0.1:6379> RPUSH list d e f
(integer) 9
LINDEX
通过元素在列表中的位置获取到这个元素,位置称为索引号/下标,
位置支持正整数和负整数
列表中元素的位置中,第一位是 0,最后一位是列表总长度减 1 或者是 -1
127.0.0.1:6379> LINDEX list 0
"c"
LRANGE
获取列表表一个区间的值
127.0.0.1:6379> LRANGE list 0 2
1) "c"
2) "b"
3) "a"
LPUSHX
向列表左端添加元素,只有key存在时才可以添加
127.0.0.1:6379> EXISTS list1
(integer) 0
127.0.0.1:6379> LPUSHX list1 a
(integer) 0
127.0.0.1:6379> LPUSHX list g
(integer) 10
RPUSHX
向列表右端添加元素,其他与LPUSHX相同
LPOP
将左端列表元素弹出,会将其从列表中删除,如果key不存在则返回(nil)
127.0.0.1:6379> LPOP list
"g"
127.0.0.1:6379> LPOP list
"c"
RPOP
将右端列表元素弹出,其他同LPOP
LLEN
返回列表的长度,如果列表不存在则返回0
127.0.0.1:6379> LLEN list
(integer) 8
127.0.0.1:6379> LLEN list1
(integer) 0
LREM
lrem key count value
删除列表中指定的值,返回值为删除的元素的个数,count值有以下几种:
count > 0: 从列表的头开始,向尾部搜索,移除与value相等的元素,移除count个
count < 0: 从列表尾部开始,向头部搜索,移除与value相等的元素,移除-count个
count == 0: 移除列表中所有与value相等的
3.Hash
HSET key field value
将哈希表key中的域 (field) 设置成指定的value,如果key不存在则新建一个hash表,如果域不存在则新建域,如果域已存在则更新域,如果field不存在返回1表示新建,存在则返回0表示更新
127.0.0.1:6379> HSET userinfo username 'shark'
(integer) 1
127.0.0.1:6379> HSET userinfo userpsw '123456'
(integer) 1
127.0.0.1:6379> HSET userinfo userpsw '654321'
(integer) 0
HGET key field
获取哈希表key中的域field的值,如果key或者field不存在则返回(nil)
127.0.0.1:6379> HGET userinfo2 username
(nil)
127.0.0.1:6379> HGET userinfo username
"stronger"
127.0.0.1:6379> HGET userinfo email
(nil)
HSETNX key field value
将哈希表中的域field设置成指定的值,只有field不存在时才可以成功,如果field存在操作无效,返回0
127.0.0.1:6379> HGET userinfo username
"stronger"
127.0.0.1:6379> HSETNX userinfo username 'fish'
(integer) 0
127.0.0.1:6379> HGET userinfo username
"stronger"
HMSET key field vale [field value]
同时将多个field-value设定到hash表中,如果field已存在值则会被覆盖掉
127.0.0.1:6379> HMSET userinfo email 'yangdm@gmail.com' sex 'male'
OK
HMGET key field [field]
同时获得key存储的hansh表中多个field的值,如果不存在则返回(nil)
127.0.0.1:6379> HMGET userinfo email sex age
1) "yangdm@gmail.com"
2) "male"
3) (nil)
HGETALL key
返回key存储的所有field及value
127.0.0.1:6379> HGETALL userinfo
1) "username"
2) "stronger"
3) "userpsw"
4) "654321"
5) "email"
6) "yangdm@gmail.com"
7) "sex"
8) "male"
127.0.0.1:6379> HGETALL userinfo2
(empty list or set)
HKEYS key
返回hash的所有域
127.0.0.1:6379> HKEYS userinfo
1) "username"
2) "userpsw"
3) "email"
4) "sex"
HVALS key
返回hash的所有域的值
127.0.0.1:6379> HVALS userinfo
1) "stronger"
2) "654321"
3) "yangdm@gmail.com"
4) "male"
HEXISTS key field
检测key中存储的hash中field是否存在,存在返回1,否则返回0
127.0.0.1:6379> HEXISTS userinfo username
(integer) 1
127.0.0.1:6379> HEXISTS userinfo age
(integer) 0
HLEN key
返回key中存储的hash表中field的数量
127.0.0.1:6379> HLEN userinfo
(integer) 4
HINCRBY key field increment
给key中存储的hash表field增加increment,如果此field不存在,则创建值为0的field,然后增加increment。操作的字段必须是整数,参照字符串处理
127.0.0.1:6379> HINCRBY userinfo age 10
(integer) 10
HINCRBYFLOAT key field increment
给key中存储的hash表field增加increment,可以为浮点数,参照字符串处理
127.0.0.1:6379> HINCRBYFLOAT userinfo salary 150.56
"150.56"
HDEL key field [field]
删除key中存储的hash表的field,可以删除一个或多个,成功返回被移除域的数量
127.0.0.1:6379> HKEYS userinfo
1) "username"
2) "userpsw"
3) "email"
4) "sex"
5) "age"
6) "salary"
127.0.0.1:6379> HDEL userinfo salary age
(integer) 2
127.0.0.1:6379> HKEYS userinfo
1) "username"
2) "userpsw"
3) "email"
4) "sex"
4.Set
Redis 的 Set 是 String 类型的无序集合。集合成员是唯一的,这就意味着集合中不能出现重复的数据。
Redis 中集合是通过哈希表实现的。
// 向集合中添加一个或者多个元素
SADD key member [member ...]
// 返回一个集合中的所有成员
SMEMBERS key
// 获取集合中元素的个数
SCARD key
// 返回所有集合的差集,就是存在于第一个集合中,且不存在于其他集合中的成员
SDIFF key [key ...]
// 交集,就是所有集合共有的元素
SINTER key [key ...]
// 并集, 就是所有集合的元素合并在一起,并去重
SUNION key [key ...]
// 差集, 返回第一集合中独有的元素
SDIFF key [key...]
Example
127.0.0.1:6379> sadd s1 a b
(integer) 2
127.0.0.1:6379> sadd s2 a b c d
(integer) 4
127.0.0.1:6379> sadd s3 c d e f
(integer) 4
127.0.0.1:6379> sdiff s2 s1
1) "d"
2) "c"
127.0.0.1:6379> SINTER s1 s2
1) "b"
2) "a"
127.0.0.1:6379> SUNION s1 s2 s3
1) "b"
2) "c"
3) "d"
4) "f"
5) "a"
6) "e"
127.0.0.1:6379> SMEMBERS s1
1) "b"
2) "a"
5.Sort Set
有序集合,在集合的基础上,为每元素排序;元素的排序需要根据另外一个值来进行比较,所以,对于有序集合,每一个元素有两个值,即:值和分数,分数专门用来做排序。
// 向有序集合添加一个或多个成员,或者更新已存在成员的分数
ZADD key score1 member1 [score2 member2]
// score1 是成员的分数
// member 是有序集合中的成员
// 获取有序集合的元素个数
ZCARD key
// 返回有序集合中的所有成员
127.0.0.1:6379> zrange sort_s 0 -1
1) "no"
2) "hello"
// 返回有序集合中的所有成员及其索引号(分数)
127.0.0.1:6379> zrange sort_s 0 -1 withscores
1) "no"
2) "1"
3) "hello"
4) "2"
127.0.0.1:6379>
出现下面的错误,是操作的命令和这个命令所能操作的数据类型不符合。
(error) WRONGTYPE Operation against a key holding the wrong kind of value