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), ...
随机推荐
- springmvc拦截请求
springmvc.xml <!--拦截请求 --> <mvc:interceptors> <mvc:interceptor> <!-- 要拦截的请求类型 / ...
- spring boot单元测试之MockMvc
spring单元测试之MockMvc,这个只是模拟,并不是真正的servlet,所以session.servletContext是没法用的. @RunWith(SpringRunner.class) ...
- 记录 nginx和php安装完后的URL重写,访问空白和隐藏index.php文件的操作方法
sudo cd /etc/nginx/; sudo vi fastcgi_params; 1.URL重写 如果你的url参数不是用?xxx传递,而是自定义的,比如用/xx/xx/xx的方式传递,那么在 ...
- Windows下OSGEarth的编译过程
目录 1. 依赖 1) OpenSceneGraph 2) GDAL 3) CURL 4) GEOS 5) 其他 2. 编译 1) 设置参数 2) 配置路径 3) 生成编译 3. 参考文献 1. 依赖 ...
- pip与conda的区别
pip和conda到底有什么不一样? 今天看到我的foreman开始报错去询问才发现.我们的python包管理工具已经从pip整体迁移到了conda..最近的迁移真的非常多..前端也在迁移打包 跟着发 ...
- 解决IE8placeholder属性问题
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- chromedriver配置
需要先安装chrome浏览器,添加chrome源 sudo vim /etc/yum.repos.d/google-chrome.repo 添加以下内容 [google-chrome] name=go ...
- 基于STM32之UART串口通信协议(二)发送
一.前言 1.简介 在上一篇UART详解中,已经有了关于UART的详细介绍了,也有关于如何使用STM32CubeMX来配置UART的操作了,而在该篇博客,主要会讲解一下如何实现UART串口的发送功能. ...
- 利用mapWithState实现按照首字母统计的有状态的wordCount
最近在做sparkstreaming整合kafka的时候遇到了一个问题: 可以抽象成这样一个问题:有状态的wordCount,且按照word的第一个字母为key,但是要求输出的格式为(word,1)这 ...
- 驰骋工作流引擎-CCMobile与安卓、IOS集成过程中的问题与解决方案
CCMobile与安卓.IOS集成过程中的问题与解决方案 前言: CCMobile(2019版本)是CCFlow&JFlow 的一款移动端审批的产品.系统基于mui框架开发,是一款可以兼容An ...