redis基本操作命令
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis基本操作命令相关的知识,希望对你有一定的参考价值。
参考技术Aredis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
MULTI
说明:
标记一个事务块的开始。
事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令原子性(atomic)地执行。
返回值:
总是返回 OK 。
示例:
DISCARD
说明:
取消事务,放弃执行事务块内的所有命令。
如果正在使用 WATCH 命令监视某个(或某些) key,那么取消所有监视,等同于执行命令 UNWATCH 。
返回值:
总是返回 OK 。
示例:
WATCH
说明:
监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
返回值:
总是返回 OK 。
UNWATCH
说明:
取消 WATCH 命令对所有 key 的监视。
如果在执行 WATCH 命令之后, EXEC 命令或 DISCARD 命令先被执行了的话,那么就不需要再执行 UNWATCH 了。
因为 EXEC 命令会执行事务,因此 WATCH 命令的效果已经产生了;而 DISCARD 命令在取消事务的同时也会取消所有对 key 的监视,因此这两个命令执行之后,就没有必要执行 UNWATCH 了。
返回值:
总是返回 OK 。
EXEC
说明:
执行所有事务块内的命令。
假如某个(或某些) key 正处于 WATCH 命令的监视之下,且事务块中有和这个(或这些) key 相关的命令,那么 EXEC 命令只在这个(或这些) key 没有被其他命令所改动的情况下执行并生效,否则该事务被打断(abort)。
返回值:
事务块内所有命令的返回值,按命令执行的先后顺序排列。
当操作被打断时,返回空值 nil 。
示例:
Redis 提供了简单的事务,之所以说它简单,主要是因为它不支持事务中的回滚特性,同时无法实现命令之间的逻辑关系计算,当然也体现了 Redis 的 “keep it simple” 的特性。
Redis 数据结构操作相关命令
文章目录
Redis 数据结构操作相关命令
redis提供5种 string 字符串 list 列表 set 集合 zset 有序集合 hash
Redis服务器相关命令
keys查看
# 查找所有符合给定模式的key
keys 查询相应的key或通配符(*)
# 用于检查给定 key 是否存在 返回0/1 0不存在,1存在
exists key
# 查看当前数据库中设置key的数量
dbsize
# 清除当前数据库中的数据
flushdb
# 切换数据库
select N
# 清除所有数据库中的数据
flushall
注:flushdb 还是flushall 两个尽量不要用,知道就行,在开发时,可以用一用,上线一定不要用。
字符串(string)操作命令
# 用于设置给定 key 的值。如果 key 已经存储其他值, SET 就覆写旧值,且无视类型
set key value [ex 秒数]/[px 毫秒数] [nx]/[xx]
注后两个参数一般不写
- ex/px 缓存有效期 ex
- nx: 表示key不存在时,执行操作
- xx: 表示key存在时,执行操作
select 1
set name yyl
get name
设置带过期时间的key
set overtime guoqi ex 4
exists overtime
查看value类型
type aa
type a
存在则添加失败,不存在则添加成功 nx
set name yyl nx
set name yangyongli nx
存在则修改,不存在则添加 xx
set name yyl xx
set name yangyongli xx
set name yylyyl xx
设置key有效期
expire name 3000
ttl name
获取key
# 用于获取指定 key 的值。如果 key 不存在,返回 nil 。如果key 储存的值不是字符串类型,返回一个错误
get key
一次性设置多个键值,语法如下:
mset key1 value1 key2 value2 …
# 获取多个key的值
mget key1 key2 key3 …
自增与自减 直接用,key自动创建,不需要先set
incr key # 自增 每次自增1
decr key # 自减 每次自减1
incrby key step # 指定步长的自增 可为负数
decrby key step # 指定步长的自减
例如
127.0.0.1:6379> incr number
(integer) 1
127.0.0.1:6379> incr number
(integer) 2
127.0.0.1:6379> decr number
(integer) 1
127.0.0.1:6379> incrby number 5
(integer) 6
127.0.0.1:6379> decrby number 6
(integer) 0
把value追加到key的原值上
append key value
设置新值同步返回旧值
getset key newValue
列表(list)操作命令
类似于PHP中的索引数组,列表中的值是可以重复的。可以用列表来实现简单的队列。
可以实现先进后出,还可以实现先进先出
把值插入到列表的头部(左边)
lpush key value
从列表右边(尾部)删除元素,并返回删除的元素值
rpop key
注:使用lpush 和 rpop 实现了 先进先出。
获取列表的长度
llen key
返回指定区间内的元素,下标从0开始
lrange key startIndex endIndex
注: 默认从左开始向右获取指定索引的值,从右开始负数开始,-1就是右边第1个元素。
从尾部添加
rpush key value
从头部删除元素并返回删除元素值
lpop key
移除列表的最后一个元素,并将该元素添加到另一个列表并返回
rpoplpush mylist otherlist
例如下面测试:
127.0.0.1:6379> lpush leftlist 1
(integer) 1
127.0.0.1:6379> rpop leftlist
"1"
127.0.0.1:6379> llen leftlist
(integer) 0
127.0.0.1:6379> lpush leftlist 1 2 3 4 5 6 7 8 9
(integer) 9
127.0.0.1:6379> lrange leftlist 3 6
1) "6"
2) "5"
3) "4"
4) "3"
127.0.0.1:6379> rpush leftlist 10
(integer) 10
127.0.0.1:6379> lpop leftlist
"9"
127.0.0.1:6379> lpop leftlist
"8"
127.0.0.1:6379> lpop leftlist
"7"
127.0.0.1:6379> lpop leftlist
"6"
127.0.0.1:6379> rpoplpush leftlist mylist
"10"
哈希(hash)操作命令
类似于PHP的关联数组。一般用于存储数据表中一条记录值。
注:关于hash的key的起名称:一般和数据表关联
表名:主键字段名:id值
user:id:1 hash的key值
下面看一下哈希操作的语法:
基本操作:
# 把key中 field字段的值设置为 value,如果没有field字段,直接添加,如果有,则覆盖原field字段的值
hset key field value
# 一次性设置多个
hmset key field1 value1 field2 value2 …
# 获取key中指定field字段的值
hget key field
# 一次性获取之个key中field字段的值
hmget key field1 field2 …
# 返回key中所有字段的值
hgetall key
例如
实战操作:把数据库中用户表中id为1的用户信息存到redis中,给hash中的key值单个设置值和单个key中的字段来获取。
hset user id 1
hset user name zhangsan
hset user age 20
hget user id
hget user name
hget user age
批量获取和添加操作:
# 删除key中指定的field字段
hdel key field
# 返回key中元素的数量
hlen key
# 判断key中有没有field字段
hexists key field
# 把key中field字段的值自增长:步长可以为负数
hincrby key field step
# 返回所有key对应的field字段
hkeys key
# 返回所有key对应field字段对应的值
hvals key
测试如下:
127.0.0.1:6379> hdel user age
(integer) 1
127.0.0.1:6379> hlen user
(integer) 2
127.0.0.1:6379> hexists user id
(integer) 1
127.0.0.1:6379> hexists user age
(integer) 0
127.0.0.1:6379> hincrby user id 4
(integer) 5
127.0.0.1:6379> hkey user
(error) ERR unknown command 'hkey'
127.0.0.1:6379> hkeys user
1) "id"
2) "name"
127.0.0.1:6379> hvals user
1) "5"
2) "zhangsan"
集合(set)操作命令
redis的set是无序集合。集合里不允许有重复的元素。
set元素最大可以包含(2的32次方-1)个元素。
操作如下:
# 向集合key中添加元素
sadd key value1 value2
# 返回key集合中所有的元素
smembers key
# 返回key集合中元素的个数
scard key
# 删除key集合中为value1的元素
srem key value1
# 随机删除key集合中的1个元素并返回
spop key
# 判断value是否存在于key集合中
sismember key value
# 把源集合中的value删除,并添加到目标集合中 【移动】
smvoe sSet dSet value
交集并集
# 求出key1,key2两个集合的交集,并返回
sinter key1 key2
# 求出key1,key2两个集合的并集,并去重,并返回
sunion key1 key2
# 求出key1与key2的差集
# 以key1集合为主,求出key1中和key2不同的元素并返回
sdiff key1 key2
实战场景:存放用户Id,不重复的信息 抽奖,好友关系
sadd userid 1 2 3 4 5 6
smembers userid
scard userid
spop userid
smembers userid
sismember userid 1
有序集合(zset)操作命令
和set一样有序集合,元素不允许重复,不同的是每个元素都会关联一个分值。
可以通过它的分值来进行排序。如实现手机APP市场的软件排名等需求的实现。
# 给key有序集合中添加元素
zadd key score(分值) value
# 删除key有序集合中指定的元素
zrem key value1
# 返回有序集中,指定区间位置内的成员
zrange key startIndex endIndex [withscores] # 从小到大排列
zrevrange key startIndex endIndex [withscores] # 从大到小排列
# 按照分值来删除元素,删除score在 min<=score<=max之间的
zremrangebyscore key min max
# 返回集合元素个数
zcard key
# 返回min <= score <= max分值区间内元素的数量
zcount key minScore maxScore
# 返回有序集中,成员的分数值
zscore key value
# 对有序集合中指定成员的分数加上增量 把value的分数+score值
zincrby key score 元素
测试如下:
127.0.0.1:6379> zadd phone 12 huawei
(integer) 1
127.0.0.1:6379> zadd phone 1 apple
(integer) 1
127.0.0.1:6379> zadd phone 11 vivo
(integer) 1
127.0.0.1:6379> zremrangebyscore phone 0 22
(integer) 3
127.0.0.1:6379> zcard phone
(integer) 0
以上是关于redis基本操作命令的主要内容,如果未能解决你的问题,请参考以下文章