Redis(四)--- Redis的命令参考
1、简述
数据类型也称数据对象,包含字符串对象(string)、列表对象(list)、哈希对象(hash)、集合对象(set)、有序集合对象(zset)。
2、String数据类型命令
string 类型是redis最基础的数据类型,为简单key-value结构,并且value不限制类型,可以是数字,字符,图片等序列化对象,value值最大不可超过512M。
string类型在使用中经常用作分布式session共享,计数器,验证码过期,基础数据的缓存等。
在java编码中使用都是使用封装好的jar包,如spring redis,jedis等等,当封装的方法名称与命令行直接操作大同小异,下面展示命令行使用:
命令 | 用法 | 描述 |
set |
SET key value [EX seconds] [PX milliseconds] [NX|XX] |
|
get | GET key |
|
mset | MSET key value [key value ...] |
|
mget | MGET key [key ...] |
|
setex | SETEX key seconds value |
|
setnx | SETNX key value |
|
psetex | SETEX key milliseconds value |
|
getset | GETSET key value |
|
strlen | STRLEN key |
|
append | APPEND key value |
|
setrange | SETRANGE key offset value |
|
getrange | GETRANGE key start end |
|
incr | INCR key |
|
incrby | INCR key increment |
|
incrbyfloat | INCRBYFLOAT key increment |
|
decr | DECR key |
|
decrby | DECRBY key decrement |
|
msetnx | MSETNX key value [key value ...] |
|
注:redis的命令无大小写区分,但key值严格区分大小写
参数:
- EX seconds ---- 设置过期时间为秒,例:EX 60
- PX milliseconds ---- 设置过期时间为毫秒,例:PX 1000
- NX ---- 只有当key值不存在时才设置
- XX ---- 只有当key值存在时才设置
3、list数据类型命令
list数据类型为key-value键值对结构,但是其value值的结构为list,类似java中的队列;左侧为表头,右侧为表尾;结构类似于java的Map<String,List<Object>>
list数据类型可以作为消息队列使用,还可以作为排名等的缓存,也可以作为缓存分页。
命令 | 用法 | 描述 |
lpush |
LPUSH key value [value ...] |
|
lpushx | LPUSHX key value |
|
rpush | ROUSH key value [value ...] |
|
rpushx | RPUSHX key value |
|
lpop | LPOP key |
|
rpop | RPOP key |
|
rpoplpush | RPOPLPUSH source destination |
|
lrem | LREM key count value |
|
llen | LLEN key |
|
lindex | LINDEX key index |
|
linsert | LINSER key BEFORE|AFTER pivot value |
|
lset | LSET key index value |
|
lrange | LRANGE key start end |
|
ltrim | LTRIM key start end |
|
blpop | BLPOP key [key ...] timeout |
|
brpop | BRPOP key [key ...] timeout |
|
brpoplpush | BRPOPLPUSH source destination timeout |
|
4、hash数据类型
hash表数据类型是key-value结构,但是key为String类型,而value的结构则是field-value结构;类似于java中的Map<Sring,Map<Stirng,Object>> 结构。
hash表数据结构中field-value 的最大存储个数是 232 - 1 个;主要用途是作为key-value对象类型的缓存,在value中存储这个对象,取用时便于还原对象。
命令 | 用法 | 描述 |
hset | HSET key field value |
|
hsetnx | HSETNX key field value |
|
hget | HGET key field |
|
hexists | HEXISTS key field |
|
hdel | HDEL key field [field ...] |
|
hlen | HLEN key |
|
hstrlen | HSTRLEN key field |
|
hincrby | HINCRBY key field increment |
|
hincrbyfloat | HINCRBYFLOAT key field increment |
|
hmset | HMSET key field value [field value ...] |
|
hmget | HMGET key field [field ...] |
|
hkeys | HKEYS key |
|
hvals | HVALS key |
|
hgetall | HGETALL key |
|
5、set数据类型
set数据类型为无序集合数据类型,且数据不重复;
集合类型经常用户存储一些集合类型的数据,如微博的所有粉丝,标签等数据;结构类似java中的HashSet。
命令 | 用法 | 描述 |
sadd | SADD key value [value ...] |
|
sismember | SISMEMBER key value |
|
spop | SPOP key |
|
srandmember | SRANDMEMBER key [count] |
|
srem | SREM key value [value ...] |
|
smove | SMOVE source destination value |
|
scard | SCARD key |
|
smembers | SMEMBERS key |
|
sinter | SINTER key [key ...] |
|
sinterstore | SINTERSTORE destination key [key ...] |
|
sunion | SUNION key [key ...] |
|
sunionstore | SUNIONSTORE destination key [key ...] |
|
sdiff | SDIFF key [key ...] |
|
sdiffstore | SDIFFSTORE destination key [key ...] |
|
6、zset数据类型
zset数据类型为有序集合类型,且集合内元素不重复;
有集合通常被用作排行榜等有时间顺序或其他顺序的缓存集和;类似于java中的hashTable
命令 | 用法 | 描述 |
zadd | ZADD key score member [score member ...] |
|
zscore | ZSCORE key member |
|
zincrby | ZINCRBY key increment member |
|
zcard | ZCARD key |
|
zcount | ZCOUNT key min max |
|
zrange |
ZRANGE key start stop [WITHSCORE] |
|
zrevrange | ZREVRANGE key start top [WITHSCORE] |
|
zrangebyscore | ZRANGEBYSCORE key min max [WITHSOCRE] [LIMIT offset count] |
|
zrevrangebyscore | ZREVRANGEBYSCORE key min max [WITHSCORE] [LIMIT offset count] |
|
zrank | ZRANK key member |
|
zrevrank | ZREVRANK key member |
|
zrem | ZREM key member [member ...] |
|
zremrangebyrank | ZREMRANGEBYRANK key start stop |
|
zremrangebyscore | ZREMRANGEBYSCORE key min max |
|
zrangebylex | ZRANGEBYLEX key min max [LIMIT offset count] |
|
zlexcount | ZLEXCOUNT key min max |
|
zremrangebylex | ZREMRANGEBYLEX key min max |
|
7、redis 操作相关命令
redis除了对五大数据类型的操作命令,还有一些系统命令,可以对这个数据库进行操作,如删除key,清空数据库,手动持久化等。
命令 | 用法 | 描述 |
keys | KEYS pattern |
|
del | DEL key [key ...] |
|
exists | EXISTS key |
|
expire | EXPIRE key seconds |
|
expireat | EXPIREAT key seconds-timestamp |
|
pexpire | PEXPIRE key milliseconds |
|
pexpireat | PEXPIREAT key milliseconds-timestamp |
|
move | MOVE key db |
|
randomkey | RANDOMKEY |
|
persist | PERSIST key |
|
type | TYPE key |
|
rename | RENAME key newkey |
|
renamenx | RENAMENX key newkey |
|
dbsize | DBSIZE |
|
flushdb | FLUSHDB |
|
flushall | FLUSHALL |
|
select | SELECT index |
|
swapdb | SWAPDB db1 db2 |
|
ttl | TTL key |
|
pttl | PTTL key |
|
事物相关命令 |
||
multi | MULTI |
|
exec | EXEC |
|
discard | DISCARD |
|
watch | WATCH key [key ...] |
|
unwatch | UNWATCH |
|
持久化相关命令 |
||
save | SAVE |
|
bgsave | BGSAVE |
|
bgrewriteaof | BGREWRITEAOF |
|
lastsave | LASTSAVE |
|
作为队列使用相关命令(发布订阅) |
||
publish | PUBLISH channel message |
|
subscribe | SUBSCRIBE channel [channel ...] |
|
psubscribe | PSUBSCRIBE pattern [pattern ...] |
|
unsubscribe | UNSUBSCRIBE channel [channel ...] |
|
punsubscribe | PUNSUBSCRIBE pattern [pattern ...] |
|
pubsub |
PUBSUB channels [pattern ...] |
|
注:redis内部命令还有很多,有些维护之类的命令再次不做介绍,如果用到,请参考redis官网。
8、总结
Redis的命令大体上可以分为两种,一种可以称为数据库级命令,可以对任何键值操作,如:DEL、TYPE等,第7节说到的基本都是;另一种是针对五大数据类型操作的,以上几节说道的基本都是。
(1)命令类型检查
命令的执行之前,Reddis会先检查输入的key的类型是否正确,才会决定是否执行给定的命令,也就是命令与值类型是否匹配。
(2)多态命令
如前一章说过四种数据对象每种都有两种编码方式,但在本章使用的命令确是一个;Redis在执行命令之前,会判断对象的编码方式,然后再执行对应的命令,这就是命令的多状态。
参考:
《Redis设计与实现》黄健宏著,网上对Redis的详解等
此博客为笔者使用redis很久之后,参考网络上各类文章总结性书写,原创手打,如有错误欢迎指正。
Redis(四)--- Redis的命令参考的更多相关文章
- redis(四)redis与Mybatis的无缝整合让MyBatis透明的管理缓存
redis的安装 http://liuyieyer.iteye.com/blog/2078093 redis的主从高可用 http://liuyieyer.iteye.com/blog/207809 ...
- Redis 命令参考
Redis 命令参考 http://redis.readthedocs.org/en/latest/index.html
- redis命令参考和redis文档中文翻译版
找到了一份redis的中文翻译文档,觉得适合学习和查阅.这份文档翻译的真的很良心啊,他是<Redis 设计与实现>一书的作者黄健宏翻译的. 地址:http://redisdoc.com/i ...
- Redis命令参考之复制(Replication)
Redis 支持简单且易用的主从复制(master-slave replication)功能, 该功能可以让从服务器(slave server)成为主服务器(master server)的精确复制品. ...
- Redis介绍及常用命令
一 Redis介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API.从2010年3月15日起,Redis的开发 ...
- redis 介绍和常用命令
redis 介绍和常用命令 redis简介 Redis 是一款开源的,基于 BSD 许可的,高级键值 (key-value) 缓存 (cache) 和存储 (store) 系统.由于 Redis 的键 ...
- redis的pub/sub命令
Redis 发布订阅 Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息. Redis 客户端可以订阅任意数量的频道. 下图展示了频道 cha ...
- 四. Redis事务处理
Redis目前对事务的支持还是比较简单,Redis能保证一个Client发起的事务中的命令可以连续执行,而中间不会插入其他Client的命令:当一个Client在连接中发起一个multi命令的时候,这 ...
- 【redis】redis常用命令及操作记录
redis-cli是Redis命令行界面,可以向Redis发送命令,并直接从终端读取服务器发送的回复. 它有两种主要模式:一种交互模式,其中有一个REPL(read eval print loop), ...
随机推荐
- STL函数static void (* set_malloc_handler(void (*f)()))()与函数指针解析
在C++ STL的SGI实现版本中,一级空间配置器class __malloc_alloc_template中有一个静态函数的实现如下: static void (*set_malloc_handle ...
- Redi缓存注意事项
缓存使用的场景 在一个高频访问的应用系统中,每次用户的请求需要去存储中获取数据,会对数据库造成很大的压力.容易导致数据库的奔溃.所以才会出现缓存来分担一部分的数据库的压力. 具体会产生数据库访问压力的 ...
- 手动实现 SpringMVC
前几章我们已经分析了 Spring 的源码并且手动实现了一个 IOC/DI 容器. 这章我们在自己实现的 Spring 框架的基础上实现一个 SpringMVC 框架. 我们自己实现的 Spring ...
- spring 5.x 系列第5篇 —— 整合 mybatis + druid 连接池 (xml配置方式)
源码Gitub地址:https://github.com/heibaiying/spring-samples-for-all 项目目录结构 1.创建maven工程,除了Spring基本依赖外,还需要导 ...
- ParrotSec 中文社区 QQ群认证 Openssl解密
ParrotSec 中文社区 QQ群认证 Openssl解密 下载Key.txt 打开parrot 系统,复制文件到系统.打开命令行输入 openssl enc -aes-256-cfb -d -in ...
- C语言实现贪吃蛇
日期:2018.9.11 用时:150min 项目:贪吃蛇(C语言--数组 结构体实现) 开发工具:vs2013 关键知识:数组,结构体,图形库,键位操作 源代码: #include<std ...
- TCP/IP 第三章
1,ip协议不可靠.无连接特性介绍 不可靠:计算机A往计算机B发送数据报1,若途径的路由器缓存已满,或者ttl(time to live 生存周期)到了,则路由器直接丢弃数据包1,并产生icmp数据包 ...
- shell遍历文件
取文件每行的数据,需要按列取 可以 sed 加管道 使用 awk 取列 platform="list.txt" line=`grep -vc '^$' $platform` ; ...
- java虚拟机-简介
一.什么是JVM JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现 ...
- Hive入门(四)查询优化
1 本地模式 0.7版本后Hive开始支持任务执行选择本地模式(local mode). 大多数的Hadoop job是需要hadoop提供的完整的可扩展性来处理大数据的.不过,有时hive的输入数据 ...